/*!
 * 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 {
  --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: 80%;
  font-weight: 400; }

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

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

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

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

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

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

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

.img-fluid {
  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: #212529;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0.25rem; }

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

.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;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: #dae0e5 !important; }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.border-primary {
  border-color: #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: rgba(255, 255, 255, 0.5) !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: "Roboto", Arial, sans-serif;
  background: #fff;
  font-size: 16px;
  line-height: 1.8;
  font-weight: 300;
  color: #666666;
  overflow-x: hidden;
  overflow-y: auto;
  min-height: 100%; }
  body.menu-show {
    overflow-y: auto; }

a {
  -webkit-transition: .3s all ease;
  -o-transition: .3s all ease;
  transition: .3s all ease;
  color: #D4AF37; }
  a:hover, a:focus {
    text-decoration: none;
    color: #000;
    outline: none !important; }

h1, h2, h3, h4, h5,
.h1, .h2, .h3, .h4, .h5 {
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.8);
  font-weight: 400; }

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

.ftco-navbar-light {
  background: transparent !important;
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  z-index: 3; }
  @media (max-width: 991.98px) {
    .ftco-navbar-light {
      background: #D4AF37 !important;
      position: relative;
      top: 0; } }
  .ftco-navbar-light .navbar-brand {
    color: #fff; }
    @media (min-width: 768px) {
      .ftco-navbar-light .navbar-brand {
        color: #fff; } }
    @media (min-width: 768px) {
      .ftco-navbar-light .navbar-brand.navbar-brand-black {
        color: #000000; } }
  .ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
    font-size: 14px;
    padding-top: .9rem;
    padding-bottom: .9rem;
    padding-left: 20px;
    padding-right: 20px;
    color: #fff;
    font-weight: 400;
    opacity: 1 !important; }
    .ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover {
      color: #fff; }
  .ftco-navbar-light .navbar-nav > .nav-item .dropdown-menu {
    border: none;
    background: #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;
    border-radius: 0;
    -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 .dropdown-menu .dropdown-item {
      font-size: 13px;
      color: rgba(0, 0, 0, 0.7); }
      .ftco-navbar-light .navbar-nav > .nav-item .dropdown-menu .dropdown-item:hover, .ftco-navbar-light .navbar-nav > .nav-item .dropdown-menu .dropdown-item:focus {
        color: #000000;
        background: transparent; }
  .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: #D4AF37;
      border: 1px solid #D4AF37; }
  .ftco-navbar-light .navbar-nav > .nav-item.cta.cta-colored span {
    border-color: #D4AF37; }
  .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: #D4AF37 !important; }
    .ftco-navbar-light.scrolled .nav-item.cta > a {
      color: #fff !important;
      background: #D4AF37;
      border: none !important;
      padding-top: 0.5rem !important;
      padding-bottom: .5rem !important;
      padding-left: 20px;
      padding-right: 20px;
      margin-top: 6px !important;
      -webkit-border-radius: 30px;
      -moz-border-radius: 30px;
      -ms-border-radius: 30px;
      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: #D4AF37; }
    @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.9rem !important;
      padding-bottom: 0.9rem !important;
      color: #000000 !important; }
      .ftco-navbar-light.scrolled .nav-link.active {
        color: #D4AF37 !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;
  text-transform: uppercase; }

.hero-wrap {
  width: 100%;
  height: 100%;
  position: inherit; }
  @media (max-width: 1199.98px) {
    .hero-wrap {
      background-position: center center !important; } }
  .hero-wrap .overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    content: '';
    opacity: .2;
    background: #000000; }
  .hero-wrap .slider-text {
    color: #fff; }
    .hero-wrap .slider-text h1 {
      font-size: 60px;
      color: #fff;
      line-height: 1;
      font-weight: 700; }
      @media (max-width: 991.98px) {
        .hero-wrap .slider-text h1 {
          font-size: 40px; } }
    .hero-wrap .slider-text p {
      font-size: 20px;
      line-height: 1.5;
      font-weight: 300;
      color: rgba(255, 255, 255, 0.8); }
      .hero-wrap .slider-text p strong {
        font-weight: 700; }
        .hero-wrap .slider-text p strong a {
          color: #000000; }
    .hero-wrap .slider-text .breadcrumbs {
      text-transform: uppercase;
      font-size: 13px;
      letter-spacing: 1px;
      margin-bottom: 20px;
      z-index: 99; }
      .hero-wrap .slider-text .breadcrumbs span {
        border-bottom: 2px solid rgba(255, 255, 255, 0.1);
        color: rgba(255, 255, 255, 0.7); }
        .hero-wrap .slider-text .breadcrumbs span a {
          color: #fff; }
    .hero-wrap .slider-text .bread {
      font-weight: 700 !important; }
    .hero-wrap .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; }
      .hero-wrap .slider-text .btn-primary:hover, .hero-wrap .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: #D4AF37 !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:hover, .owl-carousel .owl-dots .owl-dot:focus {
        outline: none !important; }
      .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-carousel.home-slider {
    position: relative;
    height: 750px;
    z-index: 0; }
    .owl-carousel.home-slider .slider-item {
      background-size: cover;
      background-repeat: no-repeat;
      background-position: center center;
      height: 750px;
      position: relative;
      z-index: 0; }
      @media (max-width: 1199.98px) {
        .owl-carousel.home-slider .slider-item {
          background-position: center center !important; } }
      .owl-carousel.home-slider .slider-item .overlay {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        background: #000000;
        opacity: .3; }
      .owl-carousel.home-slider .slider-item .slider-text {
        height: 750px; }
        @media (max-width: 767.98px) {
          .owl-carousel.home-slider .slider-item .slider-text {
            text-align: center; } }
        .owl-carousel.home-slider .slider-item .slider-text .author .img {
          width: 80px;
          height: 80px;
          display: block;
          -webkit-border-radius: 50%;
          -moz-border-radius: 50%;
          -ms-border-radius: 50%;
          border-radius: 50%; }
        .owl-carousel.home-slider .slider-item .slider-text .author .info {
          width: calc(100% - 80px); }
          .owl-carousel.home-slider .slider-item .slider-text .author .info h3 {
            font-size: 20px;
            margin-bottom: 0; }
            .owl-carousel.home-slider .slider-item .slider-text .author .info h3 a {
              font-weight: 600;
              color: #000000;
              text-decoration: underline; }
            .owl-carousel.home-slider .slider-item .slider-text .author .info h3 span {
              color: #000000; }
        .owl-carousel.home-slider .slider-item .slider-text .author span {
          font-size: 18px;
          color: #b3b3b3; }
        .owl-carousel.home-slider .slider-item .slider-text .subheading {
          color: #000000;
          font-weight: 700; }
        .owl-carousel.home-slider .slider-item .slider-text .text {
          padding-left: 2em;
          border-left: 1px solid rgba(255, 255, 255, 0.2);
          position: relative; }
          .owl-carousel.home-slider .slider-item .slider-text .text:after {
            position: absolute;
            top: 50%;
            left: -1px;
            -webkit-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            transform: translateY(-50%);
            content: '';
            width: 3px;
            height: 80px;
            background: #D4AF37; }
        .owl-carousel.home-slider .slider-item .slider-text h1 {
          font-size: 40px;
          color: #fff;
          line-height: 1.5;
          font-weight: 400;
          letter-spacing: 1px;
          text-transform: uppercase; }
          .owl-carousel.home-slider .slider-item .slider-text h1 a {
            color: #000000; }
          @media (max-width: 991.98px) {
            .owl-carousel.home-slider .slider-item .slider-text h1 {
              font-size: 30px; } }
        .owl-carousel.home-slider .slider-item .slider-text p {
          font-size: 18px;
          line-height: 1.5;
          font-weight: 300;
          color: rgba(255, 255, 255, 0.8); }
          .owl-carousel.home-slider .slider-item .slider-text p.sub-p {
            font-weight: 400; }
          .owl-carousel.home-slider .slider-item .slider-text p strong {
            font-weight: 700; }
            .owl-carousel.home-slider .slider-item .slider-text p strong a {
              color: #fff; }
        .owl-carousel.home-slider .slider-item .slider-text .breadcrumbs {
          text-transform: uppercase;
          font-size: 13px;
          letter-spacing: 1px; }
          .owl-carousel.home-slider .slider-item .slider-text .breadcrumbs span {
            border-bottom: 2px solid rgba(255, 255, 255, 0.1); }
            .owl-carousel.home-slider .slider-item .slider-text .breadcrumbs span a {
              color: #fff; }
    .owl-carousel.home-slider .owl-nav {
      position: absolute;
      top: 100%;
      width: 100%; }
      .owl-carousel.home-slider .owl-nav .owl-prev,
      .owl-carousel.home-slider .owl-nav .owl-next {
        position: absolute;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        margin-top: -10px;
        outline: none !important;
        -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;
        opacity: 0; }
        .owl-carousel.home-slider .owl-nav .owl-prev span:before,
        .owl-carousel.home-slider .owl-nav .owl-next span:before {
          font-size: 30px;
          color: rgba(255, 255, 255, 0.5);
          -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; }
        .owl-carousel.home-slider .owl-nav .owl-prev:hover span:before, .owl-carousel.home-slider .owl-nav .owl-prev:focus span:before,
        .owl-carousel.home-slider .owl-nav .owl-next:hover span:before,
        .owl-carousel.home-slider .owl-nav .owl-next:focus span:before {
          color: #fff; }
      .owl-carousel.home-slider .owl-nav .owl-prev {
        left: 50%;
        margin-left: -80px; }
      .owl-carousel.home-slider .owl-nav .owl-next {
        right: 50%;
        margin-right: -80px; }
    .owl-carousel.home-slider:hover .owl-nav .owl-prev,
    .owl-carousel.home-slider:hover .owl-nav .owl-next {
      opacity: 1; }
    .owl-carousel.home-slider:hover .owl-nav .owl-prev {
      left: 50%;
      margin-left: -80px; }
    .owl-carousel.home-slider:hover .owl-nav .owl-next {
      right: 50%;
      margin-right: -80px; }
    .owl-carousel.home-slider .owl-dots {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 40px;
      width: 100%;
      text-align: center; }
      @media (max-width: 767.98px) {
        .owl-carousel.home-slider .owl-dots {
          bottom: 5px; } }
      .owl-carousel.home-slider .owl-dots .owl-dot {
        width: 10px;
        height: 10px;
        margin: 5px;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.4); }
        .owl-carousel.home-slider .owl-dots .owl-dot.active {
          background: #fff; }

.container {
  max-width: 1300px; }

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

.bg-primary {
  background: #D4AF37; }

.ftc-no-pb {
  padding-bottom: 0 !important; }

.btn {
  cursor: pointer;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  border-radius: 30px;
  -webkit-box-shadow: none !important;
  box-shadow: none !important; }
  .btn:hover, .btn:active, .btn:focus {
    outline: none; }
  .btn.btn-primary {
    background: #D4AF37;
    border: 1px solid #D4AF37;
    color: #fff; }
    .btn.btn-primary:hover {
      border: 1px solid #D4AF37;
      background: transparent;
      color: #D4AF37; }
    .btn.btn-primary.btn-outline-primary {
      border: 1px solid #D4AF37;
      background: transparent;
      color: #D4AF37; }
      .btn.btn-primary.btn-outline-primary:hover {
        border: 1px solid transparent;
        background: #D4AF37;
        color: #fff; }
  .btn.btn-white {
    background: #fff;
    border: 1px solid #fff;
    color: #000000; }
    .btn.btn-white:hover, .btn.btn-white:focus, .btn.btn-white:active {
      border: 1px solid #fff;
      color: #D4AF37; }
    .btn.btn-white.btn-outline-white {
      border-color: rgba(255, 255, 255, 0.8);
      background: none;
      -webkit-border-radius: 30px;
      -moz-border-radius: 30px;
      -ms-border-radius: 30px;
      border-radius: 30px;
      border-width: 1px;
      color: #fff; }
      .btn.btn-white.btn-outline-white:hover, .btn.btn-white.btn-outline-white:focus, .btn.btn-white.btn-outline-white:active {
        background: #fff;
        border-color: #fff;
        color: #D4AF37; }

.btn-custom {
  font-weight: 500;
  color: #000;
  border-bottom: 4px solid #D4AF37; }

.ftco-services {
  margin-top: -50px;
  padding-bottom: 5em; }
  .ftco-services .services {
    display: block;
    width: 100%;
    -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-services .services .icon {
      line-height: 1.3;
      position: relative;
      width: 100px;
      height: 100px;
      background: #D4AF37;
      -webkit-border-radius: 50%;
      -moz-border-radius: 50%;
      -ms-border-radius: 50%;
      border-radius: 50%; }
      .ftco-services .services .icon span {
        font-size: 50px;
        color: #000; }
    .ftco-services .services .media-body h3 {
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 1px;
      font-size: 18px; }

@media (max-width: 767.98px) {
  .img-2 {
    height: 300px;
    margin-bottom: 40px; } }

.wrap-about {
  position: relative; }
  @media (min-width: 768px) {
    .wrap-about {
      padding-left: 6em; } }

.project {
  position: relative;
  width: 100%;
  display: block;
  overflow: hidden; }
  .project img {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
    -moz-transition: all 2s ease;
    -o-transition: all 2s ease;
    -webkit-transition: all 2s ease;
    -ms-transition: all 2s ease;
    transition: all 2s ease; }
  .project .text {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    padding: 3em;
    opacity: 1;
    -moz-transition: all 0.6s ease;
    -o-transition: all 0.6s ease;
    -webkit-transition: all 0.6s ease;
    -ms-transition: all 0.6s ease;
    transition: all 0.6s ease; }
    .project .text h3 {
      color: #fff;
      text-transform: uppercase; }
  .project .icon {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    width: 80px;
    height: 80px;
    margin: 0 auto;
    background: #D4AF37;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    border-radius: 50%;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -webkit-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
    opacity: 0; }
    .project .icon span {
      color: #fff;
      font-size: 30px; }
  .project:hover .text, .project:focus .text {
    opacity: 0;
    top: -100px; }
  .project:hover .icon, .project:focus .icon {
    opacity: 1;
    width: 140px;
    height: 140px; }
  .project:hover img, .project:focus img {
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.3);
    -o-transform: scale(1.3);
    -ms-transform: scale(1.3);
    transform: scale(1.3); }

.staff .img {
  height: 320px; }

.staff .text h3 {
  font-size: 20px;
  margin-bottom: 0; }

.staff .text .position {
  color: #D4AF37;
  display: block; }

.ftco-social {
  padding: 0; }
  .ftco-social li {
    list-style: none;
    margin-right: 10px; }

.block-20 {
  overflow: hidden;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  height: 275px;
  position: relative;
  display: block; }

@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 .desc {
    width: calc(100% - 100px); }
  .blog-entry .text .heading {
    font-size: 20px;
    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: #D4AF37; }
  .blog-entry .text .meta-chat {
    color: #b3b3b3; }
  .blog-entry .text .read {
    color: #000000;
    font-size: 14px; }

.blog-entry .meta {
  width: 100px;
  text-align: right; }
  .blog-entry .meta > div {
    display: block;
    margin-right: 5px;
    margin-bottom: 0px;
    font-size: 15px; }
    .blog-entry .meta > div a {
      color: #b3b3b3;
      font-size: 13px; }
      .blog-entry .meta > div a:hover {
        color: #cccccc; }

.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 {
      border: 1px solid #D4AF37;
      text-align: center;
      display: inline-block;
      width: 40px;
      height: 40px;
      line-height: 40px;
      border-radius: 50%; }
    .block-27 ul li.active a, .block-27 ul li.active span {
      background: #D4AF37;
      color: #fff;
      border: 1px solid transparent; }

.aside-stretch {
  background: white; }
  .aside-stretch:after {
    position: absolute;
    top: 0;
    right: 100%;
    bottom: 0;
    content: '';
    width: 360%;
    background: white; }
  @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-animate {
  opacity: 0;
  visibility: hidden; }

.bg-primary {
  background: #D4AF37 !important; }

.about-author .desc h3 {
  font-size: 24px; }

.ftco-section {
  padding: 6em 0;
  position: relative; }

.ftco-bg-dark {
  background: #3c312e; }

.ftco-footer {
  font-size: 14px;
  background: var(--dark-black);
  padding: 6em 0; }
  .ftco-footer .ftco-footer-logo {
    text-transform: uppercase;
    letter-spacing: .1em; }
  .ftco-footer .ftco-footer-widget h2 {
    font-weight: normal;
    color: var(--primary-gold);
    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: var(--primary-gold) !important;
    border: 2px solid var(--primary-gold) !important; }
    .ftco-footer .ftco-footer-widget .btn-primary:hover {
      background: var(--light-gold);
      border: 2px solid var(--light-gold) !important; }
  .ftco-footer p {
    color: rgba(255, 255, 255, 0.7); }
  .ftco-footer a {
    color: var(--primary-gold); }
    .ftco-footer a:hover {
      color: var(--light-gold); }
  .ftco-footer .ftco-heading-2 {
    font-size: 17px;
    font-weight: 400;
    color: var(--primary-gold); }
  .ftco-footer .categories li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
    .ftco-footer .categories li a span {
      color: rgba(255, 255, 255, 0.5) !important; }

.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: var(--primary-gold);
    border-radius: 50%;
    position: relative; }
    .ftco-footer-social li a span {
      position: absolute;
      font-size: 26px;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      color: var(--dark-black); }
    .ftco-footer-social li a:hover {
      background: var(--light-gold);
      color: var(--dark-black); }

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

.media .ftco-icon {
  width: 100px; }
  .media .ftco-icon span {
    color: #D4AF37; }

#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(255, 205, 205, 0.4); }
  70% {
    -webkit-box-shadow: 0 0 0 30px rgba(255, 205, 205, 0); }
  100% {
    -webkit-box-shadow: 0 0 0 0 rgba(255, 205, 205, 0); } }

@keyframes pulse {
  0% {
    -moz-box-shadow: 0 0 0 0 rgba(255, 205, 205, 0.4);
    -webkit-box-shadow: 0 0 0 0 rgba(255, 205, 205, 0.4);
    box-shadow: 0 0 0 0 rgba(255, 205, 205, 0.4); }
  70% {
    -moz-box-shadow: 0 0 0 30px rgba(255, 205, 205, 0);
    -webkit-box-shadow: 0 0 0 30px rgba(255, 205, 205, 0);
    box-shadow: 0 0 0 30px rgba(255, 205, 205, 0); }
  100% {
    -moz-box-shadow: 0 0 0 0 rgba(255, 205, 205, 0);
    -webkit-box-shadow: 0 0 0 0 rgba(255, 205, 205, 0);
    box-shadow: 0 0 0 0 rgba(255, 205, 205, 0); } }

.heading-section .subheading {
  font-weight: 400;
  font-size: 18px;
  display: block;
  margin-bottom: 0;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #b3b3b3; }

.heading-section h2 {
  font-size: 34px;
  font-weight: 500; }
  @media (max-width: 767.98px) {
    .heading-section h2 {
      font-size: 28px; } }

.heading-section.heading-section-with-line {
  position: relative; }
  .heading-section.heading-section-with-line:after {
    position: absolute;
    bottom: -20px;
    left: 0;
    width: 100%;
    height: 1px;
    content: '';
    background: #D4AF37; }

.heading-section.heading-section-white .subheading {
  color: rgba(255, 255, 255, 0.7); }

.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-top: 3.5em;
    padding-bottom: 2em;
    position: relative; }
  .testimony-section .owl-nav {
    position: absolute;
    top: 100%;
    width: 100%; }
    .testimony-section .owl-nav .owl-prev,
    .testimony-section .owl-nav .owl-next {
      position: absolute;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%);
      margin-top: -10px;
      outline: none !important;
      -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;
      opacity: 0; }
      .testimony-section .owl-nav .owl-prev span:before,
      .testimony-section .owl-nav .owl-next span:before {
        font-size: 30px;
        color: rgba(0, 0, 0, 0.2);
        -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; }
      .testimony-section .owl-nav .owl-prev:hover span:before, .testimony-section .owl-nav .owl-prev:focus span:before,
      .testimony-section .owl-nav .owl-next:hover span:before,
      .testimony-section .owl-nav .owl-next:focus span:before {
        color: #000000; }
    .testimony-section .owl-nav .owl-prev {
      left: 50%;
      margin-left: -80px; }
    .testimony-section .owl-nav .owl-next {
      right: 50%;
      margin-right: -80px; }
  .testimony-section:hover .owl-nav .owl-prev,
  .testimony-section:hover .owl-nav .owl-next {
    opacity: 1; }
  .testimony-section:hover .owl-nav .owl-prev {
    left: 50%;
    margin-left: -80px; }
  .testimony-section:hover .owl-nav .owl-next {
    right: 50%;
    margin-right: -80px; }
  .testimony-section .owl-dots {
    text-align: center; }
    .testimony-section .owl-dots .owl-dot {
      width: 10px;
      height: 10px;
      margin: 5px;
      border-radius: 50%;
      background: rgba(0, 0, 0, 0.2); }
      .testimony-section .owl-dots .owl-dot.active {
        background: #D4AF37; }

.testimony-wrap {
  display: block;
  position: relative;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(0, 0, 0, 0.8); }
  .testimony-wrap .user-img {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    position: relative;
    margin-top: -75px; }
    .testimony-wrap .user-img .quote {
      position: absolute;
      bottom: -10px;
      right: 0;
      width: 40px;
      height: 40px;
      background: #fff;
      -webkit-border-radius: 50%;
      -moz-border-radius: 50%;
      -ms-border-radius: 50%;
      border-radius: 50%; }
      .testimony-wrap .user-img .quote i {
        color: #D4AF37; }
  .testimony-wrap .name {
    font-weight: 400;
    font-size: 18px;
    margin-bottom: 0;
    color: #000000; }
  .testimony-wrap .position {
    font-size: 13px; }
  .testimony-wrap .line {
    position: relative;
    border-left: 1px solid #e6e6e6; }
    .testimony-wrap .line:after {
      position: absolute;
      top: 50%;
      left: -2px;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%);
      content: '';
      width: 3px;
      height: 30px;
      background: #D4AF37; }

@media (max-width: 767.98px) {
  .about-image {
    height: 400px;
    margin-bottom: 30px; } }

.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: .8;
    background: #000000; }

.ftco-counter {
  padding: 6em 0; }
  @media (max-width: 1199.98px) {
    .ftco-counter {
      background-position: center center !important; } }
  .ftco-counter .text strong.number {
    font-weight: 500;
    font-size: 40px;
    color: #fff;
    display: block; }
  .ftco-counter .text span {
    display: block;
    font-size: 16px;
    color: rgba(255, 255, 255, 0.8); }
  @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: #D4AF37; }
  .ftco-counter .ftco-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .1em; }

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

.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: #D4AF37; }
  .block-21 .text .meta > div {
    display: inline-block;
    font-size: 12px;
    margin-right: 5px; }
    .block-21 .text .meta > div a {
      color: gray; }

/* 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: #fafafa;
  padding: 10px; }
  .search-form .form-group {
    position: relative;
    margin-bottom: 0; }
    .search-form .form-group input {
      padding-right: 50px;
      font-size: 14px; }
  .search-form .icon {
    position: absolute;
    top: 50%;
    right: 20px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%); }

.subs-wrap {
  background: #D4AF37 !important;
  display: block;
  width: 100%;
  color: rgba(255, 255, 255, 0.7); }
  .subs-wrap h3 {
    color: #fff;
    font-size: 30px !important; }

.subscribe-form .form-group {
  position: relative;
  margin-bottom: 0;
  -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: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    border-radius: 0; }
    .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 .form-control {
    bordeR: 1px solid rgba(255, 255, 255, 0.4); }
  .subscribe-form .form-group .submit {
    color: #000000 !important;
    display: block;
    width: 100%;
    height: 52px;
    font-size: 16px;
    background: #fff !important;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    border-radius: 0; }
    .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-box {
  margin-bottom: 30px;
  padding: 25px;
  font-size: 15px;
  width: 100%; }
  .sidebar-box h3 {
    font-size: 18px;
    margin-bottom: 15px; }

.categories, .sidelink {
  padding: 0; }
  .categories li, .sidelink li {
    position: relative;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #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; }

/* Root scroll: avoid overflow-x on html — on many mobile browsers it breaks vertical page scroll.
   Clip horizontal bleed on body instead. */
html {
  height: auto;
  min-height: 100%;
  overflow-x: visible;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

#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;
  pointer-events: none;
  -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;
  pointer-events: auto; }

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

/* ============================================
   PREMIUM BHARTIK INTERIORS STYLING
   ============================================ */

/* Natural Color Scheme - Modern & Sophisticated */
:root {
  /* Premium Gold & Black Theme */
  --primary-gold: #D4AF37;       /* Rich premium gold */
  --light-gold: #E8C158;         /* Light gold accent */
  --dark-black: #1C1C1C;         /* Deep black */
  --charcoal: #2C2C2C;           /* Charcoal black */
  --white: #FFFFFF;              /* Pure white */
  --light-gray: #F5F5F5;         /* Light gray background */
  --medium-gray: #5A5A5A;        /* Medium gray text */
  --dark-gray: #333333;          /* Dark gray text */
  --accent-gold: #F4D03F;        /* Bright accent gold */
  --forest-green: #241b14;
  --dark-slate: #3a2b1c;
  --terracotta: #b88a52;
  --cream: #f8f1e7;
  --soft-gray: #6a6258;
  /* Wood navigation — walnut / stained oak */
  --nav-wood-base: #3a2618;
  --nav-wood-edge: #140c08;
  --nav-wood-shadow: rgba(8, 5, 3, 0.5);
}

/* Premium Button Styles - Gold Primary */
.btn-gold {
  background-color: var(--primary-gold);
  color: var(--dark-black);
  border: 2px solid var(--primary-gold);
  font-weight: 600;
  padding: 12px 30px;
  transition: all 0.3s ease;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 14px;
}

.btn-gold:hover,
.btn-gold:focus {
  background-color: var(--dark-black);
  color: var(--primary-gold);
  border-color: var(--dark-black);
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(28, 28, 28, 0.3);
  transform: translateY(-2px);
}

.btn-gold i {
  margin-right: 8px;
}

/* Alternative Black Button Style */
.btn-green {
  background-color: #f6eee1;
  color: var(--dark-black);
  border: 2px solid rgba(212, 175, 55, 0.55);
  font-weight: 600;
  padding: 12px 30px;
  transition: all 0.3s ease;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 14px;
}

.btn-green:hover,
.btn-green:focus {
  background-color: var(--primary-gold);
  color: var(--dark-black);
  border-color: var(--primary-gold);
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(212, 175, 55, 0.3);
  transform: translateY(-2px);
}

.btn-green i {
  margin-right: 8px;
}

.btn-review {
  background: linear-gradient(135deg, #fff7ef 0%, #f5dfcf 100%);
  color: var(--dark-black);
  border: 2px solid rgba(196, 78, 53, 0.22);
  font-weight: 600;
  padding: 12px 30px;
  transition: all 0.3s ease;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 14px;
}

.btn-review:hover,
.btn-review:focus {
  background: linear-gradient(135deg, #f0b35d 0%, #d9694c 100%);
  color: #fffaf4;
  border-color: rgba(163, 73, 49, 0.72);
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(196, 78, 53, 0.24);
  transform: translateY(-2px);
}

.btn-review i {
  margin-right: 8px;
  color: #cf5132;
}

/* Premium Button for Forms - Gold */
.btn-primary,
input[type="submit"] {
  background-color: var(--primary-gold) !important;
  border-color: var(--primary-gold) !important;
  color: var(--dark-black) !important;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn-primary:hover,
input[type="submit"]:hover,
button[type="submit"]:hover {
  background-color: var(--dark-black) !important;
  border-color: var(--dark-black) !important;
  color: var(--primary-gold) !important;
  box-shadow: 0 6px 16px rgba(28, 28, 28, 0.3) !important;
  transform: translateY(-2px);
}

/* Custom Text Link Button */
.btn-custom {
  color: var(--primary-gold);
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
  display: inline-block;
}

.btn-custom:hover {
  color: var(--dark-black);
  text-decoration: none;
  transform: translateX(5px);
}

.btn-custom .ion-ios-arrow-forward {
  margin-left: 5px;
  transition: margin-left 0.3s ease;
}

.btn-custom:hover .ion-ios-arrow-forward {
  margin-left: 10px;
}

/* Text Color Classes */
.text-gold {
  color: var(--primary-gold);
}

.text-black {
  color: var(--dark-black);
}

.text-forest {
  color: var(--dark-black);
}

/* Background Color Classes */
.bg-black {
  background-color: var(--dark-black);
}

.bg-forest {
  background-color: var(--dark-black);
}

.bg-light-gray {
  background-color: var(--light-gray);
}

.bg-cream {
  background-color: var(--light-gray);
}

/* Border Color Classes */
.border-gold {
  border-color: var(--primary-gold);
}

.border-green {
  border-color: var(--dark-black);
}

/* Premium Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Abril Fatface', serif;
  color: var(--dark-black);
  font-weight: normal;
  letter-spacing: 0.5px;
}

h1 {
  font-size: 3rem;
  line-height: 1.2;
  color: var(--dark-black);
}

h2 {
  font-size: 2.2rem;
  line-height: 1.3;
  color: var(--dark-black);
}

h3 {
  font-size: 1.5rem;
  line-height: 1.4;
  color: var(--dark-black);
}

p {
  color: var(--dark-gray);
  line-height: 1.8;
  font-family: 'Roboto', sans-serif;
}

/* Section Padding */
.section-padding {
  padding: 80px 0;
}

.home-page {
  background: #fbf9f4;
}

.home-page .container,
.home-page .container-fluid {
  padding-left: 28px;
  padding-right: 28px;
}

.home-page .ftco-section,
.home-page .ftco-services {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.home-page .ftc-no-pb {
  padding-top: 4rem;
  padding-bottom: 2rem;
}

.home-page .split-section {
  padding-top: 3.5rem !important;
  padding-bottom: 3.5rem !important;
}

.home-page .row.justify-content-center.mb-5.pb-3,
.home-page .row.justify-content-center.mb-5.pb-2 {
  margin-bottom: 2.75rem !important;
  padding-bottom: 0 !important;
}

.home-page .row.mt-5.pt-5 {
  margin-top: 2.5rem !important;
  padding-top: 0 !important;
}

.home-page .heading-section,
.home-page .heading-section.text-center,
.home-page .heading-section.ftco-animate {
  text-align: center;
}

.home-page .founder-section .heading-section,
.home-page .founder-section .heading-section.ftco-animate,
.home-page .founder-section .wrap-about {
  text-align: left;
}

.home-page .heading-section .subheading {
  color: var(--terracotta);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  margin-bottom: 0.75rem;
}

.home-page .heading-section h2 {
  margin-bottom: 1rem;
}

.home-page .heading-section p {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  color: var(--soft-gray);
}

.home-page .wrap-about {
  padding-left: 0;
}

.home-page .split-section .row.no-gutters {
  margin-left: 0;
  margin-right: 0;
}

.home-page .split-media,
.home-page .split-copy {
  padding-left: 0;
  padding-right: 0;
}

.home-page .split-media {
  padding-right: 1.5rem;
}

.home-page .split-copy {
  padding-left: 1.5rem;
}

.home-page .split-copy-body {
  max-width: 620px;
}

.home-page .wrap-about .pl-md-5,
.home-page .wrap-about .ml-md-5,
.home-page .wrap-about .pr-md-5,
.home-page .wrap-about .mr-md-5 {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.home-page .wrap-about .heading-section-with-line::after {
  display: none;
}

.home-page .founder-section .heading-section .subheading,
.home-page .founder-section .heading-section h2,
.home-page .founder-section .wrap-about p {
  margin-left: 0;
  margin-right: 0;
}

.home-page .wrap-about .mb-5,
.home-page .wrap-about .mb-md-5,
.home-page .wrap-about .pb-md-5 {
  margin-bottom: 0 !important;
}

.home-page .wrap-about .heading-section {
  margin-bottom: 1.25rem !important;
}

.home-page .wrap-about p:last-child {
  margin-bottom: 0;
}

.home-page .founder-section .wrap-about {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.home-page .founder-section .heading-section {
  margin-bottom: 1.5rem !important;
}

.home-page .founder-section .heading-section h2 {
  max-width: 560px;
}

.home-page .img-2 {
  min-height: 360px;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(28, 28, 28, 0.08);
}

.home-page .ftc-no-pb .row.no-gutters {
  align-items: center;
}

.home-page .ftco-services {
  margin-top: 0;
  background: linear-gradient(180deg, #f8f4ea 0%, #fbf9f4 100%) !important;
}

.home-page .ftco-services .services,
.home-page .process-step,
.home-page .staff,
.home-page .blog-entry .text,
.home-page .testimony-wrap {
  background: #ffffff;
  border-radius: 18px;
  box-shadow: 0 16px 38px rgba(28, 28, 28, 0.08);
}

.home-page .ftco-services .services {
  padding: 2rem 1.5rem;
  height: 100%;
  border: 1px solid rgba(212, 175, 55, 0.15);
}

.home-page .ftco-services .services .icon {
  width: 82px;
  height: 82px;
  margin: 0 auto 1rem;
}

.home-page .ftco-services .services .media-body {
  text-align: center;
}

.home-page .process-step {
  border-right: none;
  border-top: 4px solid var(--primary-gold);
  height: 100%;
}

.home-page .project {
  border-radius: 18px;
  box-shadow: 0 16px 38px rgba(28, 28, 28, 0.08);
  background: #ffffff;
}

.home-page .project .text {
  padding: 1.5rem;
  background: linear-gradient(180deg, rgba(28, 28, 28, 0.05) 0%, rgba(28, 28, 28, 0.72) 100%);
  display: flex;
  align-items: flex-end;
}

.home-page .project .text h3 {
  font-size: 1.05rem;
  line-height: 1.45;
  text-transform: none;
}

.home-page .project img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.home-page .project .icon {
  width: 56px;
  height: 56px;
  background: rgba(212, 175, 55, 0.95);
  box-shadow: 0 12px 24px rgba(28, 28, 28, 0.2);
}

.home-page .project .icon span {
  font-size: 20px;
  color: var(--dark-black);
}

.home-page .project:hover .icon,
.home-page .project:focus .icon {
  opacity: 1;
  width: 68px;
  height: 68px;
}

.home-page .project:hover .text,
.home-page .project:focus .text {
  opacity: 1;
  top: 0;
}

.home-page .project:hover img,
.home-page .project:focus img {
  transform: scale(1.06);
}

/* Homepage "What we do" image grid: tighter gutters and square corners */
.home-page .home-services-tiles .container-wrap {
  padding-left: 8px;
  padding-right: 8px;
}

.home-page .home-services-tiles .home-services-tiles__row {
  margin-left: -5px;
  margin-right: -5px;
}

.home-page .home-services-tiles .home-services-tiles__row > [class*="col-"] {
  padding-left: 5px;
  padding-right: 5px;
  margin-bottom: 0.7rem;
}

@media (min-width: 992px) {
  .home-page .home-services-tiles .home-services-tiles__row > [class*="col-"] {
    margin-bottom: 0.8rem;
  }
}

.home-page .home-services-tiles .project {
  border-radius: 0;
}

body.site-shell.home-page .home-services-tiles .project {
  border-radius: 0;
  box-shadow: 0 10px 24px rgba(25, 18, 13, 0.08);
}

@media (max-width: 767.98px) {
  .home-page .home-services-tiles .container-wrap {
    padding-left: 6px;
    padding-right: 6px;
  }

  .home-page .home-services-tiles .home-services-tiles__row {
    margin-left: -4px;
    margin-right: -4px;
  }

  .home-page .home-services-tiles .home-services-tiles__row > [class*="col-"] {
    padding-left: 4px;
    padding-right: 4px;
    margin-bottom: 0.6rem;
  }
}

.home-page .staff {
  overflow: hidden;
  height: 100%;
}

.home-page .staff .img {
  height: 240px;
}

.home-page .staff .text {
  padding: 1.5rem;
}

.home-page .staff .text p {
  margin-bottom: 0;
}

.home-page .blog-entry {
  background: #ffffff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 16px 38px rgba(28, 28, 28, 0.08);
  height: 100%;
}

.home-page .project-gallery {
  display: grid;
  grid-template-columns: 1.35fr 0.95fr 0.95fr 0.95fr;
  gap: 18px;
  grid-auto-flow: dense;
}

.home-page .gallery-card {
  position: relative;
  min-height: 230px;
  display: flex;
  align-items: flex-end;
  padding: 1.5rem;
  border-radius: 22px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: var(--surface-shadow-card);
  isolation: isolate;
  transition: transform 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
}

.home-page .gallery-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 10, 7, 0.1) 0%, rgba(15, 10, 7, 0.84) 100%);
  transition: opacity 0.35s ease;
  z-index: -1;
}

.home-page .gallery-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
  pointer-events: none;
}

.home-page .gallery-card:hover::before,
.home-page .gallery-card:focus::before {
  opacity: 0.92;
}

.home-page .gallery-card:hover,
.home-page .gallery-card:focus {
  transform: translateY(-6px);
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: var(--surface-shadow-card-hover);
}

.home-page .gallery-card-feature {
  grid-column: span 2;
  grid-row: span 2;
  min-height: 510px;
}

.home-page .gallery-card-wide {
  grid-column: span 2;
  min-height: 230px;
}

.home-page .gallery-card-tall {
  grid-row: span 2;
  min-height: 510px;
}

.home-page .gallery-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.9);
  color: var(--dark-black);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .gallery-card__content {
  max-width: 85%;
}

.home-page .gallery-card__content h3,
.home-page .gallery-card__content p {
  color: #ffffff;
}

.home-page .gallery-card__content h3 {
  font-size: 1.15rem;
  line-height: 1.35;
  margin-bottom: 0.5rem;
}

.home-page .gallery-card__content p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.86);
  line-height: 1.65;
}

.home-page .gallery-zoom {
  position: absolute;
  right: 16px;
  bottom: 16px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(212, 175, 55, 0.96);
  color: var(--dark-black);
  box-shadow: 0 14px 28px rgba(12, 9, 7, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.24);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.home-page .gallery-zoom i {
  font-size: 18px;
}

.home-page .gallery-card:hover .gallery-zoom,
.home-page .gallery-card:focus .gallery-zoom {
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 18px 34px rgba(12, 9, 7, 0.28);
  background: #f0c85a;
}

.home-page .gallery-card-feature .gallery-card__content h3 {
  font-size: 1.55rem;
}

.home-page .gallery-card-feature .gallery-card__content p,
.home-page .gallery-card-wide .gallery-card__content p {
  max-width: 520px;
}

.home-page .blog-entry .text {
  padding: 1.5rem;
  box-shadow: none;
  border-radius: 0;
}

.home-page .blog-entry .text .desc {
  width: 100%;
  padding-left: 0 !important;
}

.home-page .blog-entry .meta {
  width: 100%;
  text-align: left;
  margin-bottom: 0.75rem !important;
}

.home-page .blog-entry .meta > div {
  margin-right: 0;
}

.home-page .blog-entry .text.d-flex {
  display: block !important;
}

.home-page .testimony-section {
  background: linear-gradient(180deg, #ffffff 0%, #f7f4ed 100%);
}

.home-page .testimony-wrap {
  padding: 2rem !important;
  color: var(--dark-gray);
}

.home-page .testimony-wrap .text {
  padding-left: 0;
}

.home-page .testimony-wrap .line {
  padding-left: 1rem !important;
  margin-bottom: 1.75rem !important;
}

.home-page .testimony-wrap .line {
  border-left-color: rgba(212, 175, 55, 0.45);
}

.home-page .cta-section {
  margin: 1.5rem auto;
  border-radius: 22px;
  padding: 4rem 1.75rem;
  max-width: 1200px;
  background: linear-gradient(135deg, #2b1f16 0%, #4a3724 100%);
}

.home-page .cta-section .container {
  padding-left: 0;
  padding-right: 0;
}

.home-page .final-cta-section {
  background: linear-gradient(135deg, #221812 0%, #3e2c1f 100%);
  border-radius: 24px;
  margin: 1.5rem auto 0;
  padding: 4.5rem 0 !important;
  color: #ffffff;
}

.home-page .final-cta-section .container {
  padding-left: 2rem;
  padding-right: 2rem;
}

.home-page .final-cta-copy,
.home-page .final-cta-side {
  padding-left: 0;
  padding-right: 0;
}

.home-page .final-cta-copy {
  padding-right: 2rem;
}

.home-page .final-cta-side {
  padding-left: 2rem;
}

.home-page .final-cta-section .heading-section,
.home-page .final-cta-section .heading-section p {
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

.home-page .final-cta-section .heading-section h2 {
  max-width: 560px;
  color: #ffffff;
}

.home-page .final-cta-section .heading-section p {
  max-width: 580px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.05rem;
}

.home-page .final-cta-note {
  padding: 2rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(212, 175, 55, 0.22);
  border-radius: 18px;
  text-align: left;
}

.home-page .final-cta-note h3 {
  color: var(--primary-gold);
  margin-bottom: 0.75rem;
}

.home-page .final-cta-note p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.82);
}

.cta-buttons {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

.cta-buttons-left {
  justify-content: flex-start;
}

.cta-buttons .btn-gold,
.cta-buttons .btn-green {
  min-width: 210px;
}

.home-benefit-cta {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.28fr);
  align-items: center;
  gap: 22px;
  padding: 20px;
  overflow: hidden;
  border: 1px solid rgba(212, 175, 55, 0.24);
  border-radius: 22px;
  background: linear-gradient(180deg, #fffdf8 0%, #fff9ef 100%);
  box-shadow: 0 18px 50px rgba(32, 22, 14, 0.1);
}

.home-benefit-cta__media {
  position: relative;
  height: clamp(190px, 20vw, 220px);
  min-height: 190px;
  align-self: center;
  overflow: hidden;
  border-radius: 18px;
  background: var(--dark-black);
  box-shadow: 0 20px 40px rgba(32, 22, 14, 0.16);
}

.home-benefit-cta__media img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.home-benefit-cta__stamp {
  position: absolute;
  left: 18px;
  bottom: 18px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(28, 28, 28, 0.78);
  color: #ffffff;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
}

.home-benefit-cta__stamp strong {
  color: var(--primary-gold);
  font-size: 1.4rem;
  line-height: 1;
}

.home-benefit-cta__stamp span,
.home-benefit-cta__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-benefit-cta__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(0.35rem, 1vw, 0.7rem) clamp(0.35rem, 1vw, 0.7rem) clamp(0.35rem, 1vw, 0.7rem) 0;
}

.home-benefit-cta__eyebrow {
  color: var(--terracotta);
  margin-bottom: 0.65rem;
}

.home-benefit-cta__content h4 {
  margin-bottom: 1.25rem;
  color: var(--dark-slate);
  font-family: "Abril Fatface", serif;
  font-size: clamp(1.45rem, 4vw, 2.2rem);
  line-height: 1.18;
}

.home-benefit-cta__buttons {
  justify-content: flex-start;
}

body.home-page .home-benefit-cta__buttons .btn-gold,
body.home-page .home-benefit-cta__buttons .btn-green {
  min-width: 170px;
  max-width: none;
}

@media (max-width: 768px) {
  h1 {
    font-size: 2rem;
  }
  
  h2 {
    font-size: 1.6rem;
  }
  
  h3 {
    font-size: 1.2rem;
  }
  
  .btn-gold {
    padding: 10px 20px;
    font-size: 12px;
  }
}

/* Premium Section Styling */
.hero-section {
  position: relative;
  color: white;
  padding: 100px 0;
  background: linear-gradient(135deg, var(--dark-black) 0%, var(--charcoal) 100%);
}

.hero-text h1 {
  color: white;
  font-size: 3.5rem;
  margin-bottom: 1rem;
  font-weight: bold;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.2);
}

.hero-text p {
  color: rgba(255, 255, 255, 0.95);
  font-size: 1.1rem;
  font-weight: 300;
}

/* Section Backgrounds */
section.bg-light {
  background-color: var(--light-gray) !important;
}

section.bg-forest {
  background-color: var(--dark-black) !important;
  color: white;
}

section.bg-forest h1, section.bg-forest h2, section.bg-forest h3 {
  color: var(--primary-gold);
}

/* Premium Card Styling */
.card {
  border: none;
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(28, 28, 28, 0.08);
  border-left: 4px solid var(--primary-gold);
  background-color: var(--white);
}

.card:hover {
  box-shadow: 0 12px 32px rgba(28, 28, 28, 0.15);
  transform: translateY(-8px);
  border-left-color: var(--dark-black);
}

/* Service Cards */
.service-card {
  padding: 30px;
  text-align: center;
  background: var(--white);
  border-radius: 8px;
  transition: all 0.3s ease;
  border-top: 4px solid var(--primary-gold);
}

.service-card:hover {
  box-shadow: 0 12px 32px rgba(28, 28, 28, 0.15);
  transform: translateY(-10px);
  border-top-color: var(--dark-black);
}

.service-card h3 {
  margin-top: 20px;
  margin-bottom: 15px;
  color: var(--dark-slate);
}

.service-card p {
  font-size: 0.95rem;
  color: var(--soft-gray);
}

/* Process Step Card */
.process-step {
  padding: 30px 20px;
  background: var(--white);
  border-radius: 8px;
  transition: all 0.3s ease;
  border-right: 4px solid var(--primary-gold);
}

.process-step:hover {
  box-shadow: 0 8px 24px rgba(28, 28, 28, 0.12);
  transform: translateY(-5px);
  border-right-color: var(--dark-black);
}

.process-step h3 {
  font-size: 1.3rem;
  margin-bottom: 15px;
  color: var(--dark-black);
}

.process-step p {
  font-size: 0.95rem;
  color: var(--soft-gray);
  line-height: 1.6;
}

/* Premium Testimonial Styling */
.testimonial-card {
  background: var(--white);
  padding: 30px;
  border-left: 4px solid var(--primary-gold);
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(28, 28, 28, 0.08);
  transition: all 0.3s ease;
}

.testimonial-card:hover {
  box-shadow: 0 8px 24px rgba(28, 28, 28, 0.12);
  border-left-color: var(--dark-black);
}

.testimonial-card p {
  font-style: italic;
  color: var(--dark-gray);
}

.testimonial-card .author {
  font-weight: 600;
  color: var(--dark-black);
  margin-top: 15px;
}

/* Footer Enhancement - Natural Colors */
footer {
  background: linear-gradient(135deg, #201712 0%, #3b2a1d 100%);
  color: white;
  padding: 60px 0 20px;
}

footer h2 {
  color: var(--cream);
  font-size: 1.4rem;
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

footer p {
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.8;
}

footer a {
  color: var(--terracotta);
  transition: all 0.3s ease;
  text-decoration: none;
}

footer a:hover {
  color: var(--cream);
  text-decoration: none;
  transform: translateX(3px);
  display: inline-block;
}

footer .text-gold {
  color: var(--terracotta);
}

footer .ftco-footer-widget {
  padding: 20px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

footer .ftco-footer-widget:last-child {
  border-bottom: none;
}

/* Responsive Improvements */
@media (max-width: 992px) {
  h1 { font-size: 2.5rem; }
  h2 { font-size: 1.8rem; }
}

@media (max-width: 768px) {
  .btn-gold {
    display: block;
    width: 100%;
    text-align: center;
    margin: 10px 0;
  }
  
  .btn-green {
    display: block;
    width: 100%;
    text-align: center;
    margin: 10px 0;
  }
  
  .section-padding {
    padding: 50px 0;
  }

  .home-page .container,
  .home-page .container-fluid {
    padding-left: 18px;
    padding-right: 18px;
  }

  .home-page .ftco-section,
  .home-page .ftco-services,
  .home-page .ftc-no-pb {
    padding-top: 3.75rem;
    padding-bottom: 3.75rem;
  }

  .home-page .split-section {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }

  .home-page .img-2 {
    min-height: 280px;
    margin-bottom: 1.5rem;
  }

  .home-page .split-media,
  .home-page .split-copy {
    padding-left: 0;
    padding-right: 0;
  }

  .home-page .split-copy {
    padding-top: 0.5rem;
  }

  .home-page .row.justify-content-center.mb-5.pb-3,
  .home-page .row.justify-content-center.mb-5.pb-2 {
    margin-bottom: 2rem !important;
  }

  .home-page .row.mt-5.pt-5 {
    margin-top: 1.75rem !important;
  }

  .home-page .ftco-services .services,
  .home-page .process-step,
  .home-page .staff,
  .home-page .blog-entry,
  .home-page .testimony-wrap {
    border-radius: 14px;
  }

  .home-page .cta-section {
    padding: 3rem 1.25rem;
    margin: 1rem 0;
    border-radius: 16px;
  }

  .home-page .project {
    border-radius: 14px;
  }

  .home-page .home-services-tiles .project {
    border-radius: 0;
  }

  .home-page .project .text {
    padding: 1rem;
    min-height: 110px;
  }

  .home-page .project .text h3 {
    font-size: 0.96rem;
    line-height: 1.35;
  }

  .home-page .project .icon,
  .home-page .project:hover .icon,
  .home-page .project:focus .icon {
    width: 48px;
    height: 48px;
    opacity: 1;
    top: auto;
    bottom: 14px;
    right: 14px;
    left: auto;
    transform: none;
  }

  .home-page .project .icon span {
    font-size: 16px;
  }

  .home-page .project img,
  .home-page .project:hover img,
  .home-page .project:focus img {
    transform: none;
  }

  .home-page .project-gallery {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .home-page .gallery-card,
  .home-page .gallery-card-feature,
  .home-page .gallery-card-wide {
    grid-column: auto;
    grid-row: auto;
    min-height: 260px;
    padding: 1.1rem;
    border-radius: 16px;
  }

  .home-page .gallery-card-tall {
    grid-row: auto;
    min-height: 260px;
  }

  .home-page .gallery-card__content {
    max-width: 100%;
  }

  .home-page .gallery-card__content h3 {
    font-size: 1.05rem;
    line-height: 1.35;
  }

  .home-page .gallery-card-feature .gallery-card__content h3 {
    font-size: 1.12rem;
  }

  .home-page .gallery-card__content p {
    font-size: 0.92rem;
    line-height: 1.55;
  }

  .home-page .gallery-badge {
    top: 12px;
    left: 12px;
    padding: 7px 10px;
    font-size: 0.66rem;
  }

  .home-page .gallery-zoom {
    right: 12px;
    bottom: 12px;
    width: 44px;
    height: 44px;
  }

  .home-page .gallery-zoom i {
    font-size: 15px;
  }

  .home-page .final-cta-section {
    padding: 3rem 0 !important;
    border-radius: 18px;
  }

  .home-page .final-cta-section .container {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .home-page .final-cta-copy,
  .home-page .final-cta-side {
    padding-left: 0;
    padding-right: 0;
  }

  .home-page .final-cta-copy {
    margin-bottom: 1.5rem;
  }

  .home-page .final-cta-section .heading-section,
  .home-page .final-cta-section .heading-section p,
  .home-page .final-cta-note {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }

  .home-page .wrap-about .heading-section {
    margin-bottom: 1rem !important;
  }

  .home-page .founder-section .heading-section,
  .home-page .founder-section .heading-section.ftco-animate,
  .home-page .founder-section .wrap-about {
    text-align: center;
  }

  .home-page .founder-section .heading-section .subheading,
  .home-page .founder-section .heading-section h2,
  .home-page .founder-section .wrap-about p {
    margin-left: auto;
    margin-right: auto;
  }

  .cta-buttons-left {
    justify-content: center;
  }

  .cta-buttons {
    gap: 10px;
  }

  .cta-buttons .btn-gold,
  .cta-buttons .btn-green {
    min-width: 100%;
  }

  .home-page .testimony-wrap .line {
    padding-left: 0.85rem !important;
    margin-bottom: 1.25rem !important;
  }
}

/* CTA Section Styling */
.cta-section {
  background: linear-gradient(135deg, var(--dark-black) 0%, var(--charcoal) 100%);
  color: white;
  padding: 60px 20px;
  border-radius: 8px;
  text-align: center;
  margin: 40px 0;
}

.cta-section h2 {
  color: var(--primary-gold);
  margin-bottom: 20px;
  font-size: 2rem;
}

.cta-section h3 {
  color: var(--primary-gold);
}

.cta-section p {
  color: rgba(255, 255, 255, 0.95);
  font-size: 1.1rem;
  margin-bottom: 30px;
}

.cta-buttons {
  display: flex;
  gap: 15px;
  justify-content: center;
  flex-wrap: wrap;
}

.cta-buttons .btn-gold,
.cta-buttons .btn-green {
  flex: 1;
  min-width: 200px;
  max-width: 300px;
}

/* Info Badge */
.info-badge {
  display: inline-block;
  background: var(--terracotta);
  color: white;
  padding: 12px 24px;
  border-radius: 25px;
  font-weight: 600;
  margin: 10px;
  font-size: 0.9rem;
}

/* Natural Shadow */
.shadow-natural {
  box-shadow: 0 4px 15px rgba(45, 80, 22, 0.12), 0 8px 30px rgba(217, 118, 52, 0.08);
}

/* Creative Navigation Header — wood grain (horizontal growth lines + vertical figure) */
.navbar {
  position: relative;
  z-index: 1030;
  background-color: var(--nav-wood-base) !important;
  background-image:
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.04) 0px,
      transparent 1px,
      transparent 72px,
      rgba(0, 0, 0, 0.07) 73px,
      transparent 74px,
      transparent 168px
    ),
    repeating-linear-gradient(
      0deg,
      rgba(0, 0, 0, 0.13) 0px,
      transparent 1px,
      transparent 2px,
      rgba(255, 255, 255, 0.04) 3px,
      transparent 4px,
      transparent 7px
    ),
    linear-gradient(
      172deg,
      #524031 0%,
      #3d2818 24%,
      #2a1810 52%,
      #4a3628 78%,
      #2e1f14 100%
    ) !important;
  padding: 12px 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 235, 210, 0.14),
    inset 0 -2px 0 rgba(0, 0, 0, 0.28),
    0 6px 20px var(--nav-wood-shadow) !important;
  border-bottom: 3px solid var(--nav-wood-edge);
}

.navbar::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 6px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16), transparent);
  pointer-events: none;
  z-index: 1;
}

.navbar > .container,
.navbar > .container-fluid {
  position: relative;
  z-index: 2;
  padding-left: 24px;
  padding-right: 24px;
}

.navbar-brand {
  font-size: 1.8rem;
  font-weight: bold;
  color: var(--primary-gold) !important;
  font-family: 'Abril Fatface', serif;
  letter-spacing: 1px;
  transition: all 0.3s ease;
}

.navbar-brand:hover {
  color: var(--light-gold) !important;
}

.navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.85) !important;
  margin: 0 8px;
  font-weight: 500;
  transition: all 0.3s ease;
  position: relative;
  font-size: 0.95rem;
}

.navbar-nav .nav-link:hover {
  color: var(--primary-gold) !important;
}

.navbar-nav .nav-link::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--primary-gold);
  transition: width 0.3s ease;
}

.navbar-nav .nav-link:hover::after {
  width: 100%;
}

.navbar-nav .nav-link.active {
  color: var(--primary-gold) !important;
}

/* Sticky / scrolled navbar: template defaults to white — keep wood + readable text */
#ftco-navbar.ftco-navbar-light.scrolled {
  background-color: var(--nav-wood-base) !important;
  background-image:
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.04) 0px,
      transparent 1px,
      transparent 72px,
      rgba(0, 0, 0, 0.07) 73px,
      transparent 74px,
      transparent 168px
    ),
    repeating-linear-gradient(
      0deg,
      rgba(0, 0, 0, 0.13) 0px,
      transparent 1px,
      transparent 2px,
      rgba(255, 255, 255, 0.04) 3px,
      transparent 4px,
      transparent 7px
    ),
    linear-gradient(
      172deg,
      #524031 0%,
      #3d2818 24%,
      #2a1810 52%,
      #4a3628 78%,
      #2e1f14 100%
    ) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 235, 210, 0.14),
    inset 0 -2px 0 rgba(0, 0, 0, 0.28),
    0 6px 20px var(--nav-wood-shadow) !important;
  border-bottom: 3px solid var(--nav-wood-edge);
}

#ftco-navbar.ftco-navbar-light.scrolled::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 6px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16), transparent);
  pointer-events: none;
  z-index: 1;
}

#ftco-navbar.ftco-navbar-light.scrolled .navbar-nav > .nav-item > .nav-link,
#ftco-navbar.ftco-navbar-light.scrolled .nav-link {
  color: rgba(255, 255, 255, 0.9) !important;
}

#ftco-navbar.ftco-navbar-light.scrolled .navbar-brand {
  color: var(--primary-gold) !important;
}

#ftco-navbar.ftco-navbar-light.scrolled .navbar-toggler {
  color: rgba(255, 255, 255, 0.9) !important;
  border: none !important;
}

#ftco-navbar.ftco-navbar-light.scrolled .nav-item.active > a,
#ftco-navbar.ftco-navbar-light.scrolled .nav-link.active {
  color: var(--primary-gold) !important;
}

@media (max-width: 991.98px) {
  body.site-shell {
    padding-top: calc(78px + env(safe-area-inset-top));
  }

  #ftco-navbar.ftco-navbar-light,
  #ftco-navbar.ftco-navbar-light.scrolled,
  #ftco-navbar.ftco-navbar-light.scrolled.awake,
  #ftco-navbar.ftco-navbar-light.scrolled.sleep,
  .ftco-navbar-light,
  .ftco-navbar-light.scrolled,
  .ftco-navbar-light.scrolled.awake,
  .ftco-navbar-light.scrolled.sleep,
  #ftco-navbar,
  #ftco-navbar.scrolled {
    position: fixed !important;
    top: 0 !important;
    left: 0;
    right: 0;
    bottom: auto !important;
    width: 100%;
    margin-top: 0 !important;
    background-color: var(--nav-wood-base) !important;
    background-image:
      repeating-linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.04) 0px,
        transparent 1px,
        transparent 72px,
        rgba(0, 0, 0, 0.07) 73px,
        transparent 74px,
        transparent 168px
      ),
      repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.13) 0px,
        transparent 1px,
        transparent 2px,
        rgba(255, 255, 255, 0.04) 3px,
        transparent 4px,
        transparent 7px
      ),
      linear-gradient(
        172deg,
        #524031 0%,
        #3d2818 24%,
        #2a1810 52%,
        #4a3628 78%,
        #2e1f14 100%
      ) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 235, 210, 0.14),
      inset 0 -2px 0 rgba(0, 0, 0, 0.28),
      0 6px 20px var(--nav-wood-shadow) !important;
    z-index: 1000;
    transition: none !important;
    transform: none !important;
  }

  .navbar,
  .ftco-navbar-light,
  .ftco-navbar-light.scrolled {
    padding: 10px 0;
    border-bottom: 3px solid var(--nav-wood-edge);
  }

  .navbar > .container,
  .navbar > .container-fluid,
  .navbar-expand-lg > .container,
  .navbar-expand-lg > .container-fluid,
  #ftco-navbar .container {
    min-height: 58px;
    padding-left: 16px;
    padding-right: 16px;
  }

  .ftco-navbar-light .navbar-brand,
  .ftco-navbar-light.scrolled .navbar-brand,
  .navbar-brand {
    color: var(--primary-gold) !important;
    font-size: 1.2rem;
    letter-spacing: 0.5px;
    line-height: 1.2;
    margin-right: 12px;
    max-width: calc(100% - 92px);
    white-space: normal;
    text-transform: none;
  }

  .ftco-navbar-light .navbar-toggler,
  .ftco-navbar-light.scrolled .navbar-toggler,
  .navbar-dark .navbar-toggler {
    border: 0;
    color: #ffffff !important;
    opacity: 1;
    padding: 6px 0 6px 12px;
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: none;
  }

  .ftco-navbar-light .navbar-toggler:hover,
  .ftco-navbar-light .navbar-toggler:focus,
  .ftco-navbar-light.scrolled .navbar-toggler:hover,
  .ftco-navbar-light.scrolled .navbar-toggler:focus {
    color: #ffffff !important;
    outline: none;
  }

  .ftco-navbar-light .navbar-collapse,
  .ftco-navbar-light.scrolled .navbar-collapse,
  #ftco-navbar .navbar-collapse {
    width: 100%;
    margin-top: 10px;
    padding: 10px 0 12px;
    background: transparent;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: none;
  }

  .ftco-navbar-light .navbar-nav,
  .ftco-navbar-light.scrolled .navbar-nav,
  #ftco-navbar .navbar-nav {
    width: 100%;
    margin: 0;
    padding: 0;
    background: transparent;
  }

  .ftco-navbar-light .navbar-nav > .nav-item,
  .ftco-navbar-light.scrolled .navbar-nav > .nav-item {
    width: 100%;
  }

  .ftco-navbar-light .navbar-nav > .nav-item > .nav-link,
  .ftco-navbar-light.scrolled .nav-link,
  .navbar-nav .nav-link {
    display: block;
    margin: 0 !important;
    padding: 12px 0 !important;
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 0.98rem;
    line-height: 1.25;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  }

  .ftco-navbar-light .navbar-nav > .nav-item:last-child > .nav-link,
  .ftco-navbar-light.scrolled .navbar-nav > .nav-item:last-child > .nav-link {
    border-bottom: none;
  }

  .ftco-navbar-light .navbar-nav > .nav-item.active > a,
  .ftco-navbar-light.scrolled .nav-link.active,
  .navbar-nav .nav-link.active {
    color: var(--primary-gold) !important;
  }

  .navbar-nav .nav-link::after {
    display: none;
  }

  /* Collapsed menu must not sit above the page and eat touches (iOS / Chrome). */
  #ftco-nav.navbar-collapse.collapse:not(.show) {
    pointer-events: none !important;
  }

  #ftco-nav.navbar-collapse.collapse.show {
    pointer-events: auto;
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    right: 0;
    z-index: 1001;
    display: block;
    margin-top: 0;
    max-height: calc(100dvh - 88px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    touch-action: pan-y pinch-zoom;
    padding: 12px 16px calc(24px + env(safe-area-inset-bottom));
    background-color: var(--nav-wood-base) !important;
    background-image:
      repeating-linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.04) 0px,
        transparent 1px,
        transparent 72px,
        rgba(0, 0, 0, 0.07) 73px,
        transparent 74px,
        transparent 168px
      ),
      repeating-linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.13) 0px,
        transparent 1px,
        transparent 2px,
        rgba(255, 255, 255, 0.04) 3px,
        transparent 4px,
        transparent 7px
      ),
      linear-gradient(
        172deg,
        #524031 0%,
        #3d2818 24%,
        #2a1810 52%,
        #4a3628 78%,
        #2e1f14 100%
      ) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  #ftco-nav.navbar-collapse.collapsing {
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    right: 0;
    z-index: 1001;
    display: block;
    margin-top: 0;
    max-height: calc(100dvh - 88px);
    overflow: hidden;
    padding: 12px 16px calc(24px + env(safe-area-inset-bottom));
    background-color: var(--nav-wood-base) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  /* Hero carousel: vertical scroll must win over Owl’s drag handling */
  .home-slider.owl-carousel .owl-stage-outer,
  .home-slider.owl-carousel .owl-stage,
  .home-slider.owl-carousel .owl-item {
    touch-action: pan-y pinch-zoom;
  }
}

.site-shell {
  background: linear-gradient(180deg, #fbf7f1 0%, #f7f1e8 100%);
  color: #3b3026;
}

.site-shell .ftco-section {
  position: relative;
}

.site-shell .heading-section p,
.site-shell .page-intro p,
.site-shell .project-note p,
.site-shell .story-excerpt,
.site-shell .contact-note,
.site-shell .interior-article p,
.site-shell .sidebar-panel p,
.site-shell .contact-card p,
.site-shell .contact-panel p {
  color: var(--soft-gray);
}

.page-intro {
  margin-bottom: 2.75rem;
}

.page-intro .subheading,
.site-shell .article-eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--terracotta);
}

.page-intro h2,
.site-shell .interior-article h2 {
  color: var(--dark-black);
  line-height: 1.18;
}

.site-shell .project .text {
  padding: 28px 24px 22px;
  background: linear-gradient(180deg, rgba(16, 12, 9, 0.06) 0%, rgba(16, 12, 9, 0.72) 100%);
}

.site-shell .project .text h3 {
  margin-bottom: 8px;
  font-size: 1.15rem;
}

.site-shell .project .text p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.95rem;
  line-height: 1.65;
}

.project-note-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.project-note {
  padding: 28px 24px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(184, 138, 82, 0.16);
  box-shadow: 0 20px 45px rgba(36, 27, 20, 0.08);
}

.project-note h3 {
  margin-bottom: 10px;
  font-size: 1.05rem;
  color: var(--dark-black);
}

.story-card .block-20 {
  border-radius: 24px 24px 0 0;
  overflow: hidden;
}

.story-card .text {
  display: block !important;
  padding: 26px 26px 28px !important;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 0 0 24px 24px;
  box-shadow: 0 18px 44px rgba(36, 27, 20, 0.08);
}

.story-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-bottom: 14px;
  color: var(--soft-gray);
  font-size: 0.84rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.story-meta span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.story-card .heading {
  margin-bottom: 12px;
  line-height: 1.35;
}

.story-card .heading a,
.site-shell .sidebar-panel a,
.site-shell .interior-article a {
  color: var(--dark-black);
}

.story-card .heading a:hover,
.site-shell .sidebar-panel a:hover,
.site-shell .interior-article a:hover {
  color: var(--terracotta);
}

.story-excerpt {
  margin-bottom: 0;
  line-height: 1.72;
}

.interior-article,
.sidebar-panel,
.contact-panel {
  padding: 34px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(184, 138, 82, 0.14);
  box-shadow: 0 24px 54px rgba(36, 27, 20, 0.08);
}

.interior-article .img-fluid {
  margin: 16px 0 24px;
  border-radius: 24px;
}

.interior-article h3 {
  margin: 28px 0 14px;
  color: var(--dark-black);
}

.article-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 28px 0 10px;
}

.article-summary-card {
  padding: 20px 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(184, 138, 82, 0.12) 0%, rgba(248, 241, 231, 0.9) 100%);
}

.article-summary-card strong {
  display: block;
  margin-bottom: 8px;
  color: var(--dark-black);
  font-size: 0.92rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.article-list {
  padding-left: 1.1rem;
  color: var(--soft-gray);
}

.article-list li + li {
  margin-top: 10px;
}

.sidebar-panel + .sidebar-panel {
  margin-top: 24px;
}

.sidebar-panel h3 {
  margin-bottom: 18px;
  color: var(--dark-black);
  font-size: 1.18rem;
}

.sidebar-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.sidebar-list li {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(58, 43, 28, 0.08);
  color: var(--soft-gray);
}

.sidebar-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.sidebar-list strong {
  color: var(--dark-black);
  font-weight: 600;
}

.contact-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 34px;
}

.contact-card {
  padding: 24px 22px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(184, 138, 82, 0.14);
  box-shadow: 0 20px 42px rgba(36, 27, 20, 0.08);
}

.contact-card .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(184, 138, 82, 0.16) 0%, rgba(248, 241, 231, 0.96) 100%);
  color: var(--terracotta);
  font-size: 1.15rem;
}

.contact-card h3,
.contact-panel h3 {
  margin-bottom: 10px;
  color: var(--dark-black);
  font-size: 1.1rem;
}

.contact-card a,
.contact-panel a {
  color: var(--dark-black);
}

.contact-card a:hover,
.contact-panel a:hover {
  color: var(--terracotta);
}

.contact-panel-alt {
  background: linear-gradient(180deg, rgba(248, 241, 231, 0.96) 0%, rgba(255, 255, 255, 0.92) 100%);
}

.contact-process {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--soft-gray);
}

.contact-process li + li {
  margin-top: 12px;
}

.contact-action-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 22px;
}

.contact-action-list .btn {
  width: 100%;
  justify-content: center;
}

.site-shell .footer-note {
  color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 991.98px) {
  .project-note-grid,
  .article-summary-grid,
  .contact-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .interior-article,
  .sidebar-panel,
  .contact-panel {
    padding: 28px;
  }
}

@media (max-width: 767.98px) {
  .page-intro {
    margin-bottom: 2rem;
  }

  .project-note-grid,
  .article-summary-grid,
  .contact-summary-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .site-shell .project .text {
    padding: 24px 20px 20px;
  }

  .story-card .text,
  .interior-article,
  .sidebar-panel,
  .contact-panel {
    padding: 24px 20px !important;
  }
}

.home-page .highlight-gallery-section {
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
}

.home-page .gallery-showcase {
  padding: 2rem;
  border-radius: 34px;
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.18), transparent 28%),
    linear-gradient(135deg, #1f1611 0%, #352519 48%, #231a13 100%);
  box-shadow: 0 28px 80px rgba(25, 18, 13, 0.2);
}

.home-page .gallery-showcase__intro {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 28px;
  margin-bottom: 26px;
}

.home-page .gallery-showcase__copy {
  max-width: 620px;
}

.home-page .gallery-showcase__copy .subheading {
  color: rgba(240, 200, 90, 0.92);
}

.home-page .gallery-showcase__copy h2 {
  color: #ffffff;
  max-width: 720px;
}

.home-page .gallery-showcase__copy p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.78);
  max-width: 620px;
}

.home-page .gallery-showcase__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  min-width: 360px;
}

.home-page .gallery-stat {
  padding: 18px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  text-align: left;
}

.home-page .gallery-stat strong {
  display: block;
  margin-bottom: 6px;
  color: #ffffff;
  font-size: 1.15rem;
  letter-spacing: 0.04em;
}

.home-page .gallery-stat span {
  display: block;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.84rem;
  line-height: 1.45;
}

.home-page .highlight-gallery-section .project-gallery {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
  gap: 20px;
}

.home-page .highlight-gallery-section .gallery-card,
.home-page .highlight-gallery-section .gallery-story-card {
  min-height: 270px;
  border-radius: 28px;
}

.home-page .highlight-gallery-section .gallery-card {
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 1.75rem;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  box-shadow: 0 18px 50px rgba(10, 8, 6, 0.22);
  isolation: isolate;
}

.home-page .highlight-gallery-section .gallery-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 10, 7, 0.08) 0%, rgba(15, 10, 7, 0.86) 100%);
  z-index: -1;
  transition: opacity 0.35s ease;
}

.home-page .highlight-gallery-section .gallery-card:hover::before,
.home-page .highlight-gallery-section .gallery-card:focus::before {
  opacity: 0.94;
}

.home-page .highlight-gallery-section .gallery-card-feature {
  grid-column: span 7;
  grid-row: span 2;
  min-height: 620px;
}

.home-page .highlight-gallery-section .gallery-card-wide {
  grid-column: span 8;
}

.home-page .highlight-gallery-section .gallery-card-medium {
  grid-column: span 5;
}

.home-page .highlight-gallery-section .gallery-card-compact {
  grid-column: span 4;
}

.home-page .highlight-gallery-section .gallery-story-card {
  grid-column: span 5;
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 2rem;
  background: linear-gradient(180deg, rgba(255, 249, 238, 0.98) 0%, rgba(247, 238, 226, 0.94) 100%);
  border: 1px solid rgba(240, 200, 90, 0.16);
  box-shadow: 0 20px 48px rgba(10, 8, 6, 0.16);
}

.home-page .highlight-gallery-section .gallery-story-card h3 {
  margin: 3.5rem 0 1rem;
  color: var(--dark-black);
  font-size: 1.6rem;
  line-height: 1.28;
}

.home-page .highlight-gallery-section .gallery-story-card p {
  margin-bottom: 1.5rem;
  color: var(--soft-gray);
  line-height: 1.75;
}

.home-page .highlight-gallery-section .gallery-story-card__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.home-page .highlight-gallery-section .gallery-story-card__actions .btn {
  min-width: 185px;
}

.home-page .highlight-gallery-section .gallery-badge {
  position: absolute;
  top: 18px;
  left: 18px;
  display: inline-flex;
  align-items: center;
  padding: 8px 13px;
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.92);
  color: var(--dark-black);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.home-page .highlight-gallery-section .gallery-card__content {
  max-width: 86%;
}

.home-page .highlight-gallery-section .gallery-kicker {
  margin-bottom: 0.6rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-page .highlight-gallery-section .gallery-card__content h3,
.home-page .highlight-gallery-section .gallery-card__content p {
  color: #ffffff;
}

.home-page .highlight-gallery-section .gallery-card__content h3 {
  margin-bottom: 0.45rem;
  font-size: 1.18rem;
  line-height: 1.35;
}

.home-page .highlight-gallery-section .gallery-card-feature .gallery-card__content h3 {
  font-size: 1.75rem;
}

.home-page .highlight-gallery-section .gallery-card__content p:last-child {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.7;
}

.home-page .highlight-gallery-section .gallery-zoom {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(240, 200, 90, 0.96);
  color: var(--dark-black);
  box-shadow: 0 12px 26px rgba(12, 9, 7, 0.24);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.home-page .highlight-gallery-section .gallery-card:hover .gallery-zoom,
.home-page .highlight-gallery-section .gallery-card:focus .gallery-zoom {
  transform: translateY(-2px) scale(1.03);
  background: #f3cb63;
  box-shadow: 0 16px 30px rgba(12, 9, 7, 0.3);
}

@media (max-width: 1199.98px) {
  .home-page .gallery-showcase__intro {
    flex-direction: column;
    align-items: flex-start;
  }

  .home-page .gallery-showcase__stats {
    min-width: 0;
    width: 100%;
  }

  .home-page .highlight-gallery-section .gallery-card-feature {
    grid-column: span 12;
    grid-row: span 1;
    min-height: 500px;
  }

  .home-page .highlight-gallery-section .gallery-story-card,
  .home-page .highlight-gallery-section .gallery-card-wide,
  .home-page .highlight-gallery-section .gallery-card-medium {
    grid-column: span 6;
  }

  .home-page .highlight-gallery-section .gallery-card-compact {
    grid-column: span 6;
  }
}

@media (max-width: 767.98px) {
  .home-page .highlight-gallery-section {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }

  .home-page .gallery-showcase {
    padding: 1.2rem;
    border-radius: 22px;
  }

  .home-page .gallery-showcase__intro {
    gap: 20px;
    margin-bottom: 18px;
  }

  .home-page .gallery-showcase__stats {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .home-page .highlight-gallery-section .project-gallery {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .home-page .highlight-gallery-section .gallery-card,
  .home-page .highlight-gallery-section .gallery-card-feature,
  .home-page .highlight-gallery-section .gallery-card-wide,
  .home-page .highlight-gallery-section .gallery-card-medium,
  .home-page .highlight-gallery-section .gallery-card-compact,
  .home-page .highlight-gallery-section .gallery-story-card {
    grid-column: auto;
    min-height: 260px;
    border-radius: 18px;
  }

  .home-page .highlight-gallery-section .gallery-card {
    padding: 1.1rem;
  }

  .home-page .highlight-gallery-section .gallery-story-card {
    padding: 1.3rem;
  }

  .home-page .highlight-gallery-section .gallery-story-card h3 {
    margin-top: 3rem;
    font-size: 1.3rem;
  }

  .home-page .highlight-gallery-section .gallery-story-card__actions {
    flex-direction: column;
  }

  .home-page .highlight-gallery-section .gallery-story-card__actions .btn {
    width: 100%;
    min-width: 0;
  }

  .home-page .highlight-gallery-section .gallery-card__content {
    max-width: 100%;
  }

  .home-page .highlight-gallery-section .gallery-card-feature .gallery-card__content h3,
  .home-page .highlight-gallery-section .gallery-card__content h3 {
    font-size: 1.1rem;
  }

  .home-page .highlight-gallery-section .gallery-badge {
    top: 12px;
    left: 12px;
    padding: 7px 10px;
    font-size: 0.64rem;
  }

  .home-page .highlight-gallery-section .gallery-zoom {
    right: 12px;
    bottom: 12px;
    width: 42px;
    height: 42px;
  }
}

body.site-shell {
  background: linear-gradient(180deg, #fcf8f2 0%, #f6efe4 100%);
  color: #3b3026;
  font-family: "Roboto", sans-serif;
  line-height: 1.75;
  letter-spacing: 0.01em;
}

body.site-shell h1,
body.site-shell h2,
body.site-shell .bread,
body.site-shell .heading-section h2 {
  font-family: "Abril Fatface", serif;
  font-weight: 400;
  letter-spacing: 0.02em;
}

body.site-shell h3,
body.site-shell h4,
body.site-shell .ftco-heading-2 {
  font-weight: 500;
  letter-spacing: 0.01em;
}

body.site-shell p,
body.site-shell li,
body.site-shell a,
body.site-shell span,
body.site-shell label,
body.site-shell input,
body.site-shell textarea,
body.site-shell button {
  font-weight: 400;
}

body.site-shell:not(.home-page) .ftco-section,
body.site-shell:not(.home-page) .ftc-no-pb {
  padding-top: 5.25rem;
  padding-bottom: 5.25rem;
}

body.site-shell:not(.home-page) .page-intro {
  text-align: center;
}

body.site-shell .home-slider .slider-item .overlay {
  background: linear-gradient(135deg, rgba(19, 14, 10, 0.48) 0%, rgba(28, 28, 28, 0.72) 100%);
}

body.site-shell .home-slider .slider-item .slider-text .breadcrumbs {
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.site-shell .home-slider .slider-item .slider-text p,
body.site-shell .home-slider .slider-item .slider-text .breadcrumbs span,
body.site-shell .home-slider .slider-item .slider-text .breadcrumbs span a {
  color: rgba(255, 255, 255, 0.88);
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link {
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover,
body.site-shell .ftco-navbar-light .navbar-nav > .nav-item.active > .nav-link {
  color: var(--primary-gold) !important;
}

body.site-shell .navbar-brand {
  font-family: "Abril Fatface", serif;
  font-weight: 400;
  letter-spacing: 0.04em;
}

body.site-shell .btn-gold,
body.site-shell .btn-green,
body.site-shell .btn-primary,
body.site-shell input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 13px 28px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease, background 0.28s ease, color 0.28s ease;
}

body.site-shell .btn-gold,
body.site-shell .btn-primary,
body.site-shell input[type="submit"] {
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%) !important;
  border-color: rgba(212, 175, 55, 0.35) !important;
  color: #1c1c1c !important;
  box-shadow: 0 14px 34px rgba(212, 175, 55, 0.24);
}

body.site-shell .btn-green {
  background: rgba(255, 250, 244, 0.92);
  border-color: rgba(212, 175, 55, 0.3);
  color: #1c1c1c;
  box-shadow: 0 12px 28px rgba(32, 23, 18, 0.08);
}

body.site-shell .btn-gold:hover,
body.site-shell .btn-gold:focus,
body.site-shell .btn-primary:hover,
body.site-shell .btn-primary:focus,
body.site-shell input[type="submit"]:hover,
body.site-shell input[type="submit"]:focus,
body.site-shell .btn-green:hover,
body.site-shell .btn-green:focus {
  transform: translateY(-2px);
  text-decoration: none;
}

body.site-shell .btn-green:hover,
body.site-shell .btn-green:focus {
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%);
  border-color: rgba(212, 175, 55, 0.2);
  color: #1c1c1c;
  box-shadow: 0 16px 30px rgba(212, 175, 55, 0.18);
}

body.site-shell .btn-gold:hover,
body.site-shell .btn-gold:focus,
body.site-shell .btn-primary:hover,
body.site-shell .btn-primary:focus,
body.site-shell input[type="submit"]:hover,
body.site-shell input[type="submit"]:focus {
  box-shadow: 0 18px 32px rgba(212, 175, 55, 0.28);
}

body.site-shell .btn-review {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-width: 1px !important;
  border-radius: 999px;
  padding: 13px 28px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease, background 0.28s ease, color 0.28s ease;
  background: linear-gradient(135deg, rgba(255, 248, 241, 0.96) 0%, rgba(248, 223, 204, 0.98) 100%);
  border-color: rgba(196, 78, 53, 0.22) !important;
  color: #1c1c1c !important;
  box-shadow: 0 12px 28px rgba(75, 34, 26, 0.12);
}

body.site-shell .btn-review::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  top: 1px;
  height: 44%;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0));
  pointer-events: none;
}

body.site-shell .btn-review:hover,
body.site-shell .btn-review:focus {
  transform: translateY(-2px);
  text-decoration: none;
  background: linear-gradient(135deg, #f0b35d 0%, #d9694c 100%);
  border-color: rgba(163, 73, 49, 0.34) !important;
  color: #fffdf9 !important;
  box-shadow: 0 16px 30px rgba(196, 78, 53, 0.22);
}

body.site-shell .btn-review i {
  color: #cf5132;
}

body.site-shell .btn-review:hover i,
body.site-shell .btn-review:focus i {
  color: currentColor;
}

body.site-shell .services,
body.site-shell .staff,
body.site-shell .blog-entry,
body.site-shell .testimony-wrap,
body.site-shell .project-note,
body.site-shell .contact-card,
body.site-shell .contact-panel,
body.site-shell .sidebar-panel {
  transition: transform 0.32s ease, box-shadow 0.32s ease;
}

body.site-shell .services:hover,
body.site-shell .staff:hover,
body.site-shell .blog-entry:hover,
body.site-shell .testimony-wrap:hover,
body.site-shell .project-note:hover,
body.site-shell .contact-card:hover,
body.site-shell .contact-panel:hover,
body.site-shell .sidebar-panel:hover {
  transform: translateY(-6px);
}

body.site-shell .project {
  overflow: hidden;
  border-radius: 24px;
  box-shadow: 0 22px 50px rgba(25, 18, 13, 0.12);
}

body.site-shell .project img {
  width: 100%;
  transition: transform 0.45s ease;
}

body.site-shell .project:hover img {
  transform: scale(1.04);
}

body.site-shell .project .icon {
  border-radius: 50%;
}

body.site-shell .cta-section {
  margin: 2.5rem auto;
  padding: 4.2rem 2rem;
  max-width: 1220px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.16), transparent 30%),
    linear-gradient(135deg, #201712 0%, #3a2b1c 100%);
  box-shadow: 0 28px 80px rgba(25, 18, 13, 0.18);
}

body.site-shell .cta-section h3 {
  color: var(--primary-gold);
}

body.site-shell .cta-section p {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  color: rgba(255, 255, 255, 0.82) !important;
}

body.site-shell .ftco-footer {
  margin-top: 0;
  padding-top: 5rem;
}

body.site-shell .footer-note,
body.site-shell .ftco-footer p {
  color: rgba(255, 255, 255, 0.78);
}

.project-lens {
  margin-bottom: 4rem;
  padding: 1.4rem;
  border-radius: 34px;
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.14), transparent 28%),
    linear-gradient(135deg, #201712 0%, #302217 100%);
  box-shadow: 0 28px 80px rgba(25, 18, 13, 0.18);
}

.project-lens__shell {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 22px;
}

.project-lens__media {
  position: relative;
  min-height: 560px;
  overflow: hidden;
  border-radius: 26px;
}

.project-lens__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-lens__zoom {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%);
  color: #1c1c1c;
  box-shadow: 0 16px 32px rgba(25, 18, 13, 0.24);
}

.project-lens__content {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 2rem;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255, 250, 244, 0.98) 0%, rgba(247, 238, 226, 0.94) 100%);
  box-shadow: 0 20px 46px rgba(25, 18, 13, 0.16);
}

.project-lens__label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(212, 175, 55, 0.14);
  color: var(--terracotta);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.project-lens__content h3 {
  margin-bottom: 0;
  color: var(--dark-black);
  font-size: 1.9rem;
  line-height: 1.2;
}

.project-lens__content p {
  margin-bottom: 0;
  color: var(--soft-gray);
}

.project-lens__metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.project-lens__metrics span {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(58, 43, 28, 0.06);
  color: var(--dark-black);
  font-size: 0.8rem;
  font-weight: 500;
}

.project-lens__tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: auto;
}

.project-lens__tab {
  padding: 15px 16px;
  border: 1px solid rgba(184, 138, 82, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.64);
  color: var(--dark-black);
  text-align: left;
  cursor: pointer;
  transition: transform 0.24s ease, box-shadow 0.24s ease, background 0.24s ease, border-color 0.24s ease;
}

.project-lens__tab strong {
  display: block;
  margin-bottom: 4px;
  font-size: 0.95rem;
  font-weight: 600;
}

.project-lens__tab span {
  display: block;
  color: var(--soft-gray);
  font-size: 0.84rem;
  line-height: 1.5;
}

.project-lens__tab:hover,
.project-lens__tab.is-active {
  transform: translateY(-2px);
  background: linear-gradient(135deg, rgba(212, 175, 55, 0.16) 0%, rgba(255, 250, 244, 0.96) 100%);
  border-color: rgba(212, 175, 55, 0.28);
  box-shadow: 0 16px 28px rgba(25, 18, 13, 0.08);
}

.contact-panel .form-control {
  min-height: 58px;
  border-radius: 18px;
  border: 1px solid rgba(184, 138, 82, 0.16);
  background: rgba(255, 255, 255, 0.92);
  color: var(--dark-black);
  box-shadow: none;
}

.contact-panel textarea.form-control {
  min-height: 180px;
  resize: vertical;
}

.contact-panel .form-control:focus {
  border-color: rgba(212, 175, 55, 0.4);
  box-shadow: 0 0 0 4px rgba(212, 175, 55, 0.08);
}

.floating-contact {
  position: fixed;
  right: 20px;
  bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 9999;
}

.contact-option {
  --floating-icon-color: var(--primary-gold);
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(32, 23, 18, 0.96) 0%, rgba(58, 43, 28, 0.92) 100%);
  color: var(--floating-icon-color);
  border: 1px solid rgba(212, 175, 55, 0.24);
  box-shadow: 0 16px 30px rgba(25, 18, 13, 0.18);
  backdrop-filter: blur(16px);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.contact-option i {
  font-size: 1.12rem;
}

.contact-option.youtube {
  --floating-icon-color: #ff3b30;
}

.contact-option.google {
  --floating-icon-color: #4285f4;
}

.contact-option.call {
  --floating-icon-color: #0f62ff;
  border-color: rgba(15, 98, 255, 0.3);
  box-shadow:
    0 16px 30px rgba(25, 18, 13, 0.18),
    0 10px 24px rgba(15, 98, 255, 0.14);
}

.contact-option.whatsapp {
  --floating-icon-color: #25d366;
}

.contact-option.gallery {
  --floating-icon-color: #d4af37;
}

.contact-option:hover,
.contact-option:focus {
  transform: translateY(-3px);
  color: #1c1c1c;
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%);
  box-shadow: 0 20px 34px rgba(212, 175, 55, 0.2);
  text-decoration: none;
}

.translate-cta {
  position: fixed;
  right: 20px;
  bottom: 200px;
  z-index: 10020;
}

.translate-cta__toggle {
  width: 56px;
  height: 56px;
  border: 1px solid rgba(212, 175, 55, 0.26);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(32, 23, 18, 0.96) 0%, rgba(58, 43, 28, 0.94) 100%);
  color: var(--primary-gold);
  box-shadow: 0 18px 34px rgba(25, 18, 13, 0.2);
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
}

.translate-cta__toggle:hover,
.translate-cta__toggle:focus {
  transform: translateY(-3px);
  color: #1c1c1c;
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%);
  box-shadow: 0 22px 38px rgba(212, 175, 55, 0.2);
  outline: none;
}

.translate-cta__toggle i {
  font-size: 1.2rem;
}

.translate-cta__panel {
  position: absolute;
  right: 0;
  bottom: 72px;
  width: min(320px, calc(100vw - 32px));
  padding: 1rem;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(212, 175, 55, 0.16), transparent 30%),
    linear-gradient(180deg, rgba(255, 252, 248, 0.98) 0%, rgba(247, 239, 228, 0.96) 100%);
  border: 1px solid rgba(184, 138, 82, 0.18);
  box-shadow: 0 28px 60px rgba(25, 18, 13, 0.2);
}

.translate-cta__panel[hidden] {
  display: none !important;
}

.translate-cta__eyebrow {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--terracotta);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.translate-cta__panel h3 {
  margin-bottom: 0.45rem;
  color: var(--dark-black);
  font-size: 1.1rem;
  line-height: 1.25;
}

.translate-cta__description,
.translate-cta__status,
.translate-cta__note {
  margin-bottom: 0;
  color: #6f5b48;
  font-size: 0.88rem;
  line-height: 1.55;
}

.translate-cta__description {
  margin-bottom: 0.85rem;
}

.translate-cta__widget {
  min-height: 42px;
}

.translate-cta__widget .skiptranslate {
  width: 100%;
}

.translate-cta__widget .goog-te-gadget {
  width: 100%;
  color: #6f5b48 !important;
  font-family: "Roboto", sans-serif !important;
}

.translate-cta__widget .goog-te-gadget-simple {
  width: 100%;
  display: block;
  border: 1px solid rgba(184, 138, 82, 0.18) !important;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.9) !important;
  padding: 0.8rem 0.95rem !important;
}

.translate-cta__widget .goog-te-gadget-simple .goog-te-menu-value {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #1c1c1c !important;
}

.translate-cta__widget .goog-te-gadget-simple .goog-te-menu-value span {
  border-left: 0 !important;
  color: inherit !important;
  font-size: 0.92rem;
}

.translate-cta__widget .goog-te-gadget-simple .goog-te-menu-value img {
  margin-right: 8px;
}

.translate-cta__status {
  margin-top: 0.75rem;
}

.translate-cta__status.is-error {
  color: #a33e2c;
}

.translate-cta__quick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 0.9rem;
}

.translate-cta__chip {
  padding: 0.65rem 0.9rem;
  border: 1px solid rgba(184, 138, 82, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #1c1c1c;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.translate-cta__chip:hover,
.translate-cta__chip:focus,
.translate-cta__chip.is-active {
  transform: translateY(-1px);
  background: linear-gradient(135deg, #d4af37 0%, #ebcf7b 100%);
  border-color: rgba(212, 175, 55, 0.28);
  color: #1c1c1c;
  outline: none;
}

.translate-cta__note {
  margin-top: 0.8rem;
  color: #846649;
  font-size: 0.78rem;
}

@media (max-width: 991.98px) {
  .project-lens__shell {
    grid-template-columns: 1fr;
  }

  .project-lens__media {
    min-height: 420px;
  }
}

@media (max-width: 767.98px) {
  body.site-shell:not(.home-page) .ftco-section,
  body.site-shell:not(.home-page) .ftc-no-pb {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  body.site-shell .cta-section {
    padding: 3rem 1.2rem;
    border-radius: 22px;
    margin: 1.5rem 0;
  }

  .project-lens {
    padding: 1rem;
    border-radius: 22px;
  }

  .project-lens__media {
    min-height: 300px;
    border-radius: 18px;
  }

  .project-lens__content {
    padding: 1.3rem;
    border-radius: 18px;
  }

  .project-lens__content h3 {
    font-size: 1.35rem;
  }

  .project-lens__tabs {
    grid-template-columns: 1fr;
  }

  .floating-contact {
    right: 14px;
    bottom: 14px;
    gap: 10px;
  }

  .contact-option {
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }

  .contact-option i {
    font-size: 1rem;
  }

  .translate-cta {
    right: 14px;
    bottom: 168px;
  }

  .translate-cta__toggle {
    width: 48px;
    height: 48px;
  }

  .translate-cta__panel {
    right: 0;
    bottom: 60px;
    width: min(300px, calc(100vw - 28px));
    padding: 0.95rem;
    border-radius: 18px;
  }
}

.services-page__overview {
  padding-top: 4.9rem !important;
  padding-bottom: 2.2rem !important;
}

.services-page__hero-panel {
  position: relative;
  overflow: hidden;
  padding: 2.6rem;
  border-radius: 36px;
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.98) 0%, rgba(248, 239, 223, 0.96) 56%, rgba(239, 223, 191, 0.9) 100%);
  border: 1px solid rgba(184, 138, 82, 0.14);
  box-shadow: 0 28px 68px rgba(36, 27, 20, 0.12);
}

.services-page__hero-panel::before {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -120px;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216, 181, 111, 0.3) 0%, rgba(216, 181, 111, 0) 72%);
  pointer-events: none;
}

.services-page__hero-panel::after {
  content: "";
  position: absolute;
  left: -40px;
  top: -60px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  border: 1px solid rgba(166, 122, 72, 0.08);
  pointer-events: none;
}

.services-page__eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.86) 0%, rgba(246, 232, 201, 0.82) 100%);
  border: 1px solid rgba(166, 122, 72, 0.16);
  box-shadow: 0 10px 24px rgba(43, 29, 20, 0.06);
  color: var(--terracotta);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.services-page__hero-title {
  margin: 1rem 0 1rem;
  max-width: 11ch;
  font-family: "Abril Fatface", serif;
  font-size: clamp(2.05rem, 4vw, 3.5rem);
  line-height: 1.08;
  color: var(--dark-black);
}

.services-page__hero-lead {
  max-width: 39rem;
  margin-bottom: 0;
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--soft-gray);
}

.services-page__service-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 1.7rem 0 1rem;
}

.services-page__service-tags span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(166, 122, 72, 0.14);
  box-shadow: 0 12px 26px rgba(43, 29, 20, 0.06);
  color: var(--dark-black);
  font-size: 0.84rem;
  font-weight: 600;
}

.services-page__hero-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 1.5rem;
  color: var(--soft-gray);
  line-height: 1.7;
}

.services-page__hero-note i {
  margin-top: 0.25rem;
  color: var(--terracotta);
}

.services-page__hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.services-page__hero-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.services-page__hero-visual {
  position: relative;
  display: block;
  min-height: 560px;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 28px 48px rgba(36, 27, 20, 0.16);
}

.services-page__hero-visual img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 560px;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.services-page__hero-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(18, 13, 10, 0.04) 0%, rgba(18, 13, 10, 0.2) 40%, rgba(18, 13, 10, 0.78) 100%);
}

.services-page__hero-visual:hover img {
  transform: scale(1.04);
}

.services-page__zoom-badge {
  position: absolute;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  top: 16px;
  right: 16px;
  padding: 0.62rem 0.95rem;
  border-radius: 999px;
  background: rgba(28, 20, 15, 0.56);
  color: #fff8ed;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  backdrop-filter: blur(12px);
}

.services-page__hero-visual-note {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 1;
  display: grid;
  gap: 6px;
  padding: 1.1rem 1.15rem;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(29, 20, 15, 0.3) 0%, rgba(29, 20, 15, 0.64) 100%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff8ed;
  backdrop-filter: blur(14px);
}

.services-page__hero-visual-note strong {
  font-size: 1.1rem;
  font-weight: 700;
}

.services-page__hero-visual-note span {
  color: rgba(255, 248, 236, 0.86);
  line-height: 1.55;
}

.services-page__catalog-section {
  padding-top: 0 !important;
  padding-bottom: 2rem !important;
}

.services-page__catalog {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.services-page__service-panel {
  overflow: hidden;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255, 254, 250, 0.98) 0%, rgba(247, 239, 225, 0.95) 100%);
  border: 1px solid rgba(166, 122, 72, 0.12);
  box-shadow: var(--surface-shadow-card);
  transition: transform 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
}

.services-page__service-panel:hover {
  transform: translateY(-6px);
  border-color: rgba(166, 122, 72, 0.22);
  box-shadow: var(--surface-shadow-card-hover);
}

.services-page__service-panel--featured {
  background: linear-gradient(135deg, rgba(255, 251, 243, 0.98) 0%, rgba(241, 225, 195, 0.94) 100%);
}

.services-page__service-index {
  display: inline-block;
  margin-bottom: 0.7rem;
  color: var(--terracotta);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.services-page__panel-copy {
  display: flex;
  height: 100%;
  flex-direction: column;
  justify-content: center;
  padding: 2.5rem 2.4rem;
}

.services-page__service-panel h3 {
  margin-bottom: 0.8rem;
  color: var(--dark-black);
  font-size: clamp(1.65rem, 2vw, 2.2rem);
  line-height: 1.2;
}

.services-page__service-panel p {
  margin-bottom: 1.2rem;
  color: var(--soft-gray);
  font-size: 1rem;
  line-height: 1.82;
}

.services-page__panel-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.services-page__panel-tags span {
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(166, 122, 72, 0.14);
  box-shadow: 0 10px 24px rgba(43, 29, 20, 0.06);
  color: var(--dark-black);
  font-size: 0.82rem;
  font-weight: 600;
}

.services-page__panel-media {
  position: relative;
  display: block;
  min-height: 360px;
  overflow: hidden;
  background: #f5ece0;
}

.services-page__panel-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(18, 13, 10, 0.02) 0%, rgba(18, 13, 10, 0.12) 48%, rgba(18, 13, 10, 0.32) 100%);
}

.services-page__panel-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 360px;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.services-page__panel-media:hover img {
  transform: scale(1.04);
}

.services-page__expect-section {
  padding-top: 0 !important;
  padding-bottom: 4.6rem !important;
}

.services-page__expect-shell {
  position: relative;
  overflow: hidden;
  padding: 2.5rem;
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(29, 20, 15, 0.98) 0%, rgba(61, 43, 31, 0.96) 100%);
  border: 1px solid rgba(216, 181, 111, 0.16);
  box-shadow: 0 30px 72px rgba(22, 14, 10, 0.2);
}

.services-page__expect-shell::before {
  content: "";
  position: absolute;
  right: -90px;
  top: -90px;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216, 181, 111, 0.2) 0%, rgba(216, 181, 111, 0) 72%);
  pointer-events: none;
}

.services-page__expect-copy h2 {
  margin: 1rem 0 0.8rem;
  color: #fffdf8;
  line-height: 1.15;
}

.services-page__expect-copy p {
  margin-bottom: 0;
  color: rgba(255, 248, 236, 0.82);
  line-height: 1.8;
}

.services-page__expect-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.services-page__expect-card {
  height: 100%;
  padding: 1.4rem 1.25rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0.06) 100%);
  border: 1px solid rgba(240, 217, 163, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.services-page__expect-number {
  display: inline-block;
  margin-bottom: 0.75rem;
  color: var(--light-gold);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.services-page__expect-card h3 {
  margin-bottom: 0.55rem;
  color: #fffdf8;
  font-size: 1.1rem;
}

.services-page__expect-card p {
  margin-bottom: 0;
  color: rgba(255, 248, 236, 0.8);
  line-height: 1.72;
}

@media (max-width: 991.98px) {
  .services-page__hero-panel,
  .services-page__expect-shell {
    padding: 2.2rem;
  }

  .services-page__hero-title {
    max-width: none;
  }

  .services-page__hero-visual {
    margin-top: 2rem;
  }

  .services-page__expect-copy {
    margin-bottom: 1.75rem;
  }

  .services-page__expect-grid {
    grid-template-columns: 1fr;
  }

  .services-page__panel-copy {
    padding: 2rem 1.8rem;
  }
}

@media (max-width: 767.98px) {
  .services-page__overview {
    padding-top: 4rem !important;
    padding-bottom: 1.5rem !important;
  }

  .services-page__hero-panel,
  .services-page__expect-shell {
    padding: 1.5rem;
    border-radius: 26px;
  }

  .services-page__hero-title {
    font-size: 2rem;
  }

  .services-page__hero-lead {
    font-size: 1rem;
  }

  .services-page__service-tags {
    gap: 8px;
  }

  .services-page__service-tags span {
    font-size: 0.78rem;
    padding: 0.62rem 0.85rem;
  }

  .services-page__hero-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .services-page__catalog {
    gap: 16px;
  }

  .services-page__hero-visual,
  .services-page__hero-visual img {
    min-height: 360px;
  }

  .services-page__hero-visual-note {
    left: 14px;
    right: 14px;
    bottom: 14px;
    padding: 0.95rem;
  }

  .services-page__service-panel {
    border-radius: 24px;
  }

  .services-page__panel-copy {
    padding: 1.4rem 1.25rem 1.5rem;
  }

  .services-page__service-panel h3 {
    font-size: 1.4rem;
  }

  .services-page__panel-media,
  .services-page__panel-media img {
    min-height: 260px;
  }

  .services-page__expect-section {
    padding-bottom: 3.6rem !important;
  }

  .services-page__zoom-badge {
    top: 12px;
    right: 12px;
    font-size: 0.75rem;
  }
}

/* ========== Mira Road map page (interactive area atlas) ========== */
body.mira-map-page {
  background: linear-gradient(180deg, #fbf7f1 0%, #f4ebe0 100%);
}

/* ========== Mira Road simple page (embed + text) ========== */
body.mira-simple-page {
  background: #faf7f2;
}

.mira-simple-hero__title {
  font-family: "Abril Fatface", serif;
  font-size: 2rem;
  color: var(--dark-black);
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .mira-simple-hero__title {
    font-size: 2.35rem;
  }
}

.mira-simple-hero__lead {
  font-size: 1.05rem;
  line-height: 1.65;
  color: #4a4238;
  max-width: 42rem;
}

.mira-simple-main {
  padding-top: 0;
}

.mira-simple-map-wrap {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(60, 48, 38, 0.12);
  box-shadow: 0 8px 28px rgba(32, 22, 14, 0.08);
  background: #e8e0d4;
}

.mira-simple-map__iframe {
  display: block;
  width: 100%;
  height: 220px;
  border: 0;
}

@media (min-width: 992px) {
  .mira-simple-map__iframe {
    height: 280px;
  }
}

.mira-simple-map-links a {
  color: var(--terracotta);
  font-weight: 600;
}

.mira-simple-map-links a:hover {
  color: var(--dark-black);
}

.mira-areas-list {
  padding-left: 1.15rem;
  margin-bottom: 0;
  color: #3a342e;
}

.mira-areas-list li {
  margin-bottom: 0.65rem;
  line-height: 1.55;
}

.mira-simple-cta .btn-sm {
  margin-top: 0.25rem;
}

/* ========== Inquiry planner page (requirement brief + WhatsApp) ========== */
body.inquiry-planner-page {
  background: #f5f0e8;
}

.inquiry-planner-hero {
  position: relative;
  overflow: hidden;
  padding: 3rem 0 2.5rem;
  background: linear-gradient(155deg, #14100d 0%, #2a1f16 48%, #1a1410 100%);
  color: #f8f1e7;
  border-bottom: 3px solid var(--primary-gold);
}

@media (min-width: 992px) {
  .inquiry-planner-hero {
    padding: 3.75rem 0 3rem;
  }
}

.inquiry-planner-hero__glow {
  position: absolute;
  width: 55%;
  max-width: 480px;
  height: 180px;
  top: -36px;
  right: -4%;
  background: radial-gradient(ellipse, rgba(212, 175, 55, 0.16) 0%, transparent 72%);
  pointer-events: none;
}

.inquiry-planner-hero__kicker {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(212, 175, 55, 0.95);
  margin-bottom: 0.85rem;
}

.inquiry-planner-hero__title {
  font-family: "Abril Fatface", serif;
  font-size: 1.9rem;
  line-height: 1.22;
  color: #fff;
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .inquiry-planner-hero__title {
    font-size: 2.5rem;
  }
}

.inquiry-planner-hero__title span {
  color: var(--primary-gold);
}

.inquiry-planner-hero__lead {
  font-size: 1.02rem;
  line-height: 1.7;
  color: rgba(248, 241, 231, 0.9);
}

.inquiry-guide-section {
  padding: 2.75rem 0 1.5rem;
  background: #faf7f2;
}

.inquiry-section-heading {
  font-family: "Abril Fatface", serif;
  font-size: 1.65rem;
  color: var(--dark-black);
}

.inquiry-guide-card {
  padding: 1.25rem 1.15rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(212, 175, 55, 0.2);
  box-shadow: 0 10px 32px rgba(45, 33, 24, 0.06);
}

.inquiry-guide-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(212, 175, 55, 0.15);
  color: #8b6914;
  margin-bottom: 0.75rem;
  font-size: 1rem;
}

.inquiry-guide-card h3 {
  font-weight: 700;
  color: var(--dark-black);
  margin-bottom: 0.5rem;
}

.inquiry-builder-section {
  padding: 1rem 0 3rem;
  background: #f0ebe3;
}

.inquiry-builder-card {
  background: #fffef9;
  border-radius: 18px;
  padding: 1.75rem 1.35rem 2rem;
  box-shadow:
    0 20px 56px rgba(32, 22, 14, 0.1),
    0 0 0 1px rgba(212, 175, 55, 0.12);
}

.inquiry-builder-card fieldset {
  border: none;
  padding: 0;
  margin: 0;
  min-width: 0;
}

@media (min-width: 768px) {
  .inquiry-builder-card {
    padding: 2.25rem 2.25rem 2.5rem;
  }
}

.inquiry-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5c534a;
  margin-bottom: 0.35rem;
}

.inquiry-scope-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem 1rem;
}

@media (min-width: 576px) {
  .inquiry-scope-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.inquiry-check {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0;
  font-size: 0.92rem;
  color: #3a342e;
  cursor: pointer;
}

.inquiry-check input {
  margin-top: 0.2rem;
}

.inquiry-output-wrap {
  margin-top: 0.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(60, 48, 38, 0.1);
}

.inquiry-output {
  font-size: 0.9rem;
  line-height: 1.55;
  background: #f8f5f0 !important;
  border: 1px solid rgba(60, 48, 38, 0.12) !important;
  min-height: 16rem;
}

.inquiry-foot-section {
  padding-top: 2rem;
  padding-bottom: 3rem;
  background: #faf7f2;
}

.pi-guide-tight {
  padding-top: 1.5rem;
  padding-bottom: 0.5rem;
}

.pi-wizard-wrap {
  padding-top: 0.5rem;
}

.pi-wizard {
  max-width: 760px;
  margin: 0 auto;
  background: #fffef9;
  border-radius: 20px;
  padding: 1.5rem 1.25rem 5.5rem;
  box-shadow:
    0 24px 60px rgba(32, 22, 14, 0.1),
    0 0 0 1px rgba(212, 175, 55, 0.14);
  position: relative;
}

@media (min-width: 768px) {
  .pi-wizard {
    padding: 2rem 2rem 5.5rem;
  }
}

body.inquiry-planner-page .pi-wizard {
  max-width: 820px;
  border-radius: 22px;
  box-shadow:
    0 32px 80px rgba(32, 22, 14, 0.12),
    0 0 0 1px rgba(212, 175, 55, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.pi-step .h5 {
  font-weight: 700;
  color: var(--dark-black);
  letter-spacing: -0.01em;
}

.pi-step-hint {
  font-size: 0.88rem;
  line-height: 1.65;
  color: #5c534a;
  max-width: 38rem;
}

.pi-wizard-head {
  text-align: center;
  margin-bottom: 1.5rem;
}

.pi-wizard-eta {
  font-size: 0.8rem;
  color: var(--terracotta);
  font-weight: 600;
}

.pi-progress {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.pi-dot {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 800;
  background: #ebe5dc;
  color: #6a6258;
  border: 2px solid transparent;
}

.pi-dot.is-active {
  background: var(--primary-gold);
  color: #1c1c1c;
  border-color: #8b6914;
}

.pi-dot.is-done {
  background: #2d241c;
  color: #f8f1e7;
}

.pi-choice-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 576px) {
  .pi-choice-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.pi-choice {
  margin: 0;
  cursor: pointer;
}

.pi-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.pi-choice__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  padding: 1rem 1rem 1.1rem;
  border-radius: 14px;
  border: 2px solid rgba(60, 48, 38, 0.12);
  background: #fff;
  height: 100%;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.pi-choice__body i {
  color: var(--terracotta);
  font-size: 1.1rem;
}

.pi-choice__body strong {
  font-size: 0.95rem;
  color: var(--dark-black);
}

.pi-choice__body small {
  font-size: 0.78rem;
  color: var(--soft-gray);
  line-height: 1.35;
}

.pi-choice input:focus + .pi-choice__body,
.pi-choice input:checked + .pi-choice__body,
.pi-choice:hover .pi-choice__body {
  border-color: var(--primary-gold);
  box-shadow: 0 8px 24px rgba(212, 175, 55, 0.2);
}

.pi-choice input:checked + .pi-choice__body {
  background: linear-gradient(180deg, #fffdf6 0%, #faf4e8 100%);
}

.pi-scope-grid--full {
  grid-template-columns: 1fr;
}

@media (min-width: 576px) {
  .pi-scope-grid--full {
    grid-template-columns: 1fr 1fr;
  }
}

.pi-reno-panel {
  padding: 1rem 1rem 0.25rem;
  border-radius: 12px;
  background: rgba(212, 175, 55, 0.08);
  border: 1px dashed rgba(139, 105, 20, 0.45);
}

.pi-wizard-nav {
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

@media (min-width: 768px) {
  .pi-wizard-nav {
    left: 2rem;
    right: 2rem;
  }
}

.home-plan-inquiry-section {
  background: linear-gradient(180deg, #fffdf9 0%, #f2ebe2 100%);
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.home-plan-inquiry-section--cta-only {
  padding-top: 2.75rem;
  padding-bottom: 2.75rem;
}

.home-plan-inquiry-cta-line {
  max-width: 28rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.65;
  font-size: 0.95rem;
}

.home-plan-inquiry-cta-btn {
  font-weight: 600;
}

.home-plan-visual-cta {
  display: grid;
  grid-template-columns: minmax(210px, 0.82fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(1.35rem, 5vw, 3.5rem);
  overflow: hidden;
  padding: clamp(1.4rem, 5vw, 3rem);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(28, 28, 28, 0.96), rgba(58, 43, 28, 0.96)),
    url("../images/work-2.jpg") center / cover;
  box-shadow: 0 24px 70px rgba(32, 22, 14, 0.18);
}

.home-plan-visual-cta__mockup {
  display: flex;
  justify-content: center;
}

.home-plan-phone {
  width: min(230px, 100%);
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 18px 50px rgba(0, 0, 0, 0.24);
}

.home-plan-phone__bar {
  width: 58px;
  height: 5px;
  margin: 0 auto 18px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.42);
}

.home-plan-phone__row,
.home-plan-phone__bubble {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  margin-bottom: 10px;
  padding: 0 13px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--dark-black);
  font-size: 0.88rem;
  font-weight: 700;
}

.home-plan-phone__row i {
  color: var(--primary-gold);
}

.home-plan-phone__bubble {
  justify-content: center;
  margin: 16px 0 0;
  background: #25d366;
  color: #083f1c;
}

.home-plan-visual-cta__content {
  color: #ffffff;
}

.home-plan-visual-cta__content .home-plan-inquiry-badge {
  margin-bottom: 0.9rem;
}

.home-plan-visual-cta__content h2 {
  margin-bottom: 1rem;
  color: #ffffff;
  font-family: "Abril Fatface", serif;
  font-size: clamp(1.75rem, 5vw, 2.8rem);
  line-height: 1.1;
}

.home-plan-visual-cta__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 1.35rem;
}

.home-plan-visual-cta__chips span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid rgba(212, 175, 55, 0.32);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.82rem;
  font-weight: 700;
}

.home-plan-visual-cta__chips i {
  color: var(--primary-gold);
}

@media (max-width: 767.98px) {
  .home-benefit-cta,
  .home-plan-visual-cta {
    grid-template-columns: 1fr;
  }

  .home-benefit-cta__media,
  .home-benefit-cta__media img {
    height: 310px;
    min-height: 310px;
  }

  .home-benefit-cta__content {
    padding: 0;
    text-align: center;
  }

  .home-benefit-cta__buttons {
    justify-content: center;
  }

  .home-plan-visual-cta {
    padding: 1.25rem;
    text-align: center;
  }

  .home-plan-visual-cta__mockup {
    order: -1;
  }

  .home-plan-phone {
    width: min(210px, 100%);
  }

  .home-plan-visual-cta__chips {
    justify-content: center;
  }
}

.home-plan-inquiry-card {
  background: #fff;
  border-radius: 18px;
  padding: 1.5rem 1.25rem 1.75rem;
  box-shadow:
    0 18px 50px rgba(32, 22, 14, 0.08),
    0 0 0 1px rgba(212, 175, 55, 0.15);
}

@media (min-width: 768px) {
  .home-plan-inquiry-card {
    padding: 2rem 2rem 2.25rem;
  }
}

.home-plan-inquiry-output {
  font-size: 0.88rem;
  line-height: 1.5;
  background: #faf8f4 !important;
}

.home-plan-inquiry-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6b5a3a;
  background: linear-gradient(180deg, #fff 0%, #f5efe6 100%);
  border: 1px solid rgba(212, 175, 55, 0.35);
  border-radius: 999px;
  padding: 0.35rem 0.85rem;
  margin-bottom: 0.75rem;
  max-width: 100%;
}

.home-plan-inquiry-lead {
  max-width: 32rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.65;
}

.home-plan-inquiry-ribbon h2 {
  font-family: "Abril Fatface", serif;
  font-size: clamp(1.45rem, 3.5vw, 1.85rem);
  color: var(--dark-black);
}

.home-plan-inquiry-card--compact {
  padding: 1.35rem 1.15rem 1.5rem;
}

@media (min-width: 768px) {
  .home-plan-inquiry-card--compact {
    padding: 1.65rem 1.65rem 1.85rem;
  }
}

.home-plan-inquiry-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.5rem;
}

.inquiry-check--pill {
  border: 1px solid rgba(60, 48, 38, 0.12);
  border-radius: 999px;
  padding: 0.35rem 0.75rem 0.35rem 0.55rem;
  background: #fff;
  font-size: 0.85rem;
  transition:
    border-color 0.15s ease,
    background 0.15s ease;
}

.inquiry-check--pill:hover {
  border-color: rgba(212, 175, 55, 0.55);
  background: #fffdf8;
}

.inquiry-check--pill:has(input:checked) {
  border-color: var(--primary-gold);
  background: linear-gradient(180deg, #fffdf6 0%, #faf4e8 100%);
  font-weight: 600;
  color: #2d241c;
}

.mira-map-hero {
  position: relative;
  overflow: hidden;
  padding: 4.5rem 0 3.5rem;
  background: linear-gradient(145deg, #1a120c 0%, #2d2118 42%, #1f1510 100%);
  color: #f8f1e7;
  border-bottom: 4px solid var(--terracotta);
}

@media (min-width: 992px) {
  .mira-map-hero {
    padding: 5.5rem 0 4rem;
  }
}

.mira-map-hero__grid {
  position: absolute;
  inset: 0;
  opacity: 0.14;
  background-image:
    linear-gradient(rgba(212, 175, 55, 0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 175, 55, 0.1) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}

.mira-map-hero__glow {
  position: absolute;
  width: 55%;
  max-width: 520px;
  height: 120%;
  top: -10%;
  right: -8%;
  background: radial-gradient(ellipse at center, rgba(212, 175, 55, 0.22) 0%, transparent 68%);
  pointer-events: none;
}

.mira-map-hero__row {
  min-height: 280px;
}

@media (min-width: 992px) {
  .mira-map-hero__row {
    min-height: 340px;
  }
}

.mira-map-hero__eyebrow {
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(232, 193, 88, 0.95);
  margin-bottom: 1rem;
  font-weight: 600;
}

.mira-map-hero__eyebrow i {
  margin-right: 0.45rem;
  opacity: 0.9;
}

.mira-map-hero__title {
  font-family: "Abril Fatface", serif;
  font-size: clamp(2.1rem, 5vw, 3.35rem);
  line-height: 1.12;
  color: #fff;
  margin-bottom: 1.1rem;
}

.mira-map-hero__title span {
  color: var(--primary-gold);
  display: inline-block;
}

.mira-map-hero__lead {
  font-size: 1.08rem;
  line-height: 1.75;
  color: rgba(248, 241, 231, 0.88);
  max-width: 34rem;
  margin-bottom: 1.75rem;
}

.mira-map-hero__stats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem 2rem;
}

.mira-map-hero__stats li {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.mira-map-hero__stats strong {
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--primary-gold);
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.02em;
}

.mira-map-hero__stats span {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(248, 241, 231, 0.55);
}

.mira-map-hero__card {
  display: inline-block;
  text-align: left;
  max-width: 320px;
  padding: 1.75rem 1.5rem;
  border-radius: 20px;
  background: rgba(255, 250, 244, 0.06);
  border: 1px solid rgba(212, 175, 55, 0.35);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(8px);
}

.mira-map-hero__card-pin {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, #d4af37 0%, #e8c158 100%);
  color: #1a120c;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  margin-bottom: 1rem;
  box-shadow: 0 10px 28px rgba(212, 175, 55, 0.35);
}

.mira-map-hero__card-title {
  font-weight: 700;
  font-size: 1.05rem;
  color: #fff;
  margin-bottom: 0.5rem;
}

.mira-map-hero__card-text {
  font-size: 0.92rem;
  line-height: 1.6;
  color: rgba(248, 241, 231, 0.78);
  margin: 0;
}

.mira-map-explorer {
  padding: 2.5rem 0 3.5rem;
  position: relative;
}

.mira-map-explorer__fluid {
  max-width: 1480px;
  margin: 0 auto;
  padding-left: 12px;
  padding-right: 12px;
}

@media (min-width: 992px) {
  .mira-map-explorer__fluid {
    padding-left: 24px;
    padding-right: 24px;
  }
}

.mira-map-explorer__intro {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}

.mira-map-explorer__tagline {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--terracotta);
  margin-bottom: 0.75rem;
}

.mira-map-explorer__tagline i {
  margin-right: 0.4rem;
  opacity: 0.9;
}

.mira-map-explorer__note {
  font-size: 0.98rem;
  line-height: 1.75;
  color: var(--soft-gray);
}

.mira-map-explorer__note i {
  color: var(--terracotta);
  margin-right: 0.35rem;
}

/* Corridor chips + gold line (quick jump strip) */
.mira-corridor-chips-wrap {
  margin: 0 auto 1.75rem;
  max-width: 1200px;
}

.mira-corridor-chips__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
  margin-bottom: 0.65rem;
}

.mira-corridor-chips__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(60, 48, 38, 0.55);
  flex-shrink: 0;
}

.mira-corridor-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  flex: 1;
  min-width: 0;
  justify-content: flex-start;
}

@media (max-width: 991.98px) {
  .mira-corridor-chips {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
    margin-left: -4px;
    margin-right: -4px;
    padding-left: 4px;
    padding-right: 4px;
    scrollbar-width: thin;
  }

  .mira-chip {
    flex-shrink: 0;
  }
}

.mira-chip {
  border: 1px solid rgba(212, 175, 55, 0.45);
  background: rgba(255, 255, 255, 0.92);
  color: var(--dark-black);
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  cursor: pointer;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.15s ease;
}

.mira-chip:hover {
  border-color: var(--primary-gold);
  box-shadow: 0 4px 14px rgba(212, 175, 55, 0.22);
  transform: translateY(-1px);
}

.mira-chip:focus {
  outline: none;
}

.mira-chip:focus-visible {
  outline: 2px solid var(--primary-gold);
  outline-offset: 2px;
}

.mira-chip.is-active {
  background: linear-gradient(135deg, #d4af37 0%, #b8941f 100%);
  border-color: #8b6914;
  color: #1c1c1c;
  box-shadow: 0 6px 20px rgba(184, 148, 31, 0.35);
}

.mira-chip--home {
  border-left: 3px solid #c9a227;
}

.mira-chip--landmark {
  border-left: 3px solid #b88a52;
}

.mira-chip--transit {
  border-left: 3px solid #5a6a8a;
}

.mira-corridor-line {
  margin: 0;
  height: 28px;
  opacity: 0.85;
}

.mira-corridor-line__svg {
  width: 100%;
  height: 28px;
  display: block;
}

/* Map + glass sidebar theatre */
.mira-map-theatre {
  display: grid;
  grid-template-columns: 1fr minmax(288px, 400px);
  gap: 1.25rem;
  align-items: stretch;
}

.mira-map-theatre__map-col {
  min-width: 0;
}

.mira-map-frame--theatre {
  height: 100%;
  min-height: min(72vh, 720px);
}

.mira-map-frame--theatre .mira-road-map-canvas,
.mira-map-frame--theatre .mira-map-fallback-iframe {
  height: 100%;
  min-height: min(72vh, 720px);
}

.mira-map-frame__badge--theatre {
  max-width: calc(100% - 32px);
  line-height: 1.35;
  letter-spacing: 0.08em;
}

.mira-map-theatre__glass {
  display: flex;
  flex-direction: column;
  min-height: min(72vh, 720px);
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255, 253, 248, 0.78);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(212, 175, 55, 0.38);
  box-shadow:
    0 24px 60px rgba(45, 33, 24, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.mira-map-theatre__glass-inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.mira-map-glass__kicker {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--terracotta);
  padding: 1.1rem 1.25rem 0;
  margin: 0;
}

.mira-map-sidebar__head--glass {
  padding-top: 0.65rem;
}

.mira-map-theatre__glass .mira-map-list {
  max-height: none;
  flex: 1;
  min-height: 0;
}

.mira-map-theatre__glass .mira-map-presence {
  margin-left: 1rem;
  margin-right: 1rem;
}

.mira-map-explorer__row {
  margin-left: -8px;
  margin-right: -8px;
  align-items: stretch;
}

.mira-map-explorer__row > [class*="col-"] {
  padding-left: 8px;
  padding-right: 8px;
}

.mira-map-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow:
    0 28px 70px rgba(32, 22, 14, 0.18),
    0 0 0 1px rgba(212, 175, 55, 0.2);
  background: #e8e0d4;
}

.mira-road-map-canvas {
  width: 100%;
  height: min(72vh, 720px);
  min-height: 420px;
}

.mira-road-map-canvas--fallback {
  line-height: 0;
  background: #e8e0d4;
}

.mira-map-fallback-iframe {
  width: 100%;
  height: min(72vh, 720px);
  min-height: 420px;
  border: 0;
  display: block;
}

.mira-map-frame__badge {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 2;
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(28, 28, 28, 0.88);
  color: rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.mira-map-frame__badge i {
  margin-right: 0.4rem;
  color: var(--primary-gold);
}

.mira-map-sidebar {
  height: 100%;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, #fffdf9 0%, #f5ebe0 100%);
  border-radius: 24px;
  border: 1px solid rgba(212, 175, 55, 0.28);
  box-shadow: 0 20px 50px rgba(45, 33, 24, 0.1);
  overflow: hidden;
}

.mira-map-sidebar__head {
  padding: 1.35rem 1.25rem 1rem;
  border-bottom: 1px solid rgba(60, 48, 38, 0.1);
  flex-shrink: 0;
}

.mira-map-sidebar__label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--soft-gray);
  margin-bottom: 0.65rem;
}

.mira-map-search-wrap {
  position: relative;
}

.mira-map-search-wrap__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(60, 48, 38, 0.35);
  font-size: 0.9rem;
  pointer-events: none;
}

.mira-map-search {
  width: 100%;
  padding: 12px 14px 12px 40px;
  border-radius: 12px;
  border: 1px solid rgba(212, 175, 55, 0.35);
  font-size: 0.95rem;
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.mira-map-search:focus {
  outline: none;
  border-color: var(--primary-gold);
  box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.2);
}

.mira-map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  margin-top: 0.85rem;
  font-size: 0.78rem;
  color: var(--soft-gray);
}

.mira-map-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.mira-map-legend__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.mira-map-legend__dot--home {
  background: linear-gradient(135deg, #c9a227, #8b6914);
}

.mira-map-legend__dot--landmark {
  background: linear-gradient(135deg, #b88a52, #7a4e24);
}

.mira-map-legend__dot--transit {
  background: linear-gradient(135deg, #5a6a8a, #3a4258);
}

.mira-map-reset {
  width: 100%;
  margin-top: 0.9rem;
  padding: 10px 14px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 12px;
  border: 1px solid rgba(28, 28, 28, 0.12);
  background: rgba(255, 255, 255, 0.85);
  color: var(--dark-black);
  transition: background 0.2s ease, transform 0.2s ease;
}

.mira-map-reset:hover {
  background: var(--primary-gold);
  color: #1c1c1c;
  border-color: var(--primary-gold);
}

.mira-map-reset i {
  margin-right: 0.35rem;
}

.mira-map-list {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0 0.75rem;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  max-height: min(38vh, 360px);
}

@media (min-width: 992px) {
  .mira-map-list {
    max-height: min(42vh, 400px);
  }
}

.mira-map-presence {
  flex-shrink: 0;
  margin: 0 0.85rem 1rem;
  padding: 1.15rem 1.1rem;
  border-radius: 16px;
  background: linear-gradient(165deg, rgba(255, 252, 246, 0.98) 0%, #f5ebe0 100%);
  border: 1px solid rgba(212, 175, 55, 0.45);
  box-shadow: 0 12px 32px rgba(45, 33, 24, 0.1);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.mira-map-presence[hidden] {
  display: none !important;
}

.mira-map-presence--visible {
  animation: miraPresenceIn 0.45s ease forwards;
}

@keyframes miraPresenceIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.mira-map-presence__eyebrow {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--terracotta);
  margin-bottom: 0.45rem;
}

.mira-map-presence__title {
  font-family: "Abril Fatface", serif;
  font-size: 1.15rem;
  line-height: 1.3;
  color: var(--dark-black);
  margin-bottom: 0.35rem;
}

.mira-map-presence__sub {
  font-size: 0.8rem;
  color: var(--soft-gray);
  margin-bottom: 0.65rem;
  line-height: 1.45;
}

.mira-map-presence__note {
  font-size: 0.88rem;
  line-height: 1.55;
  color: #4a4238;
  margin-bottom: 0.65rem;
}

.mira-map-presence__proof {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
  color: rgba(60, 48, 38, 0.65);
  margin-bottom: 0.85rem;
}

.mira-map-presence__wa {
  font-size: 0.78rem !important;
  padding: 10px 14px !important;
  letter-spacing: 0.06em;
}

.mira-map-list__item + .mira-map-list__item {
  border-top: 1px solid rgba(60, 48, 38, 0.06);
}

.mira-map-list__btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.95rem 1.1rem;
  border: none;
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: background 0.2s ease;
}

.mira-map-list__btn:hover,
.mira-map-list__btn.is-active {
  background: rgba(212, 175, 55, 0.12);
}

.mira-map-list__btn.is-active {
  border-left: 3px solid var(--primary-gold);
  padding-left: calc(1.1rem - 3px);
}

.mira-map-list__kind {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  flex-shrink: 0;
}

.mira-map-list__item[data-kind="home"] .mira-map-list__kind {
  background: linear-gradient(135deg, #c9a227, #8b6914);
}

.mira-map-list__item[data-kind="landmark"] .mira-map-list__kind {
  background: linear-gradient(135deg, #b88a52, #7a4e24);
}

.mira-map-list__item[data-kind="transit"] .mira-map-list__kind {
  background: linear-gradient(135deg, #5a6a8a, #3a4258);
}

.mira-map-list__text {
  flex: 1;
  min-width: 0;
}

.mira-map-list__text strong {
  display: block;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--dark-black);
  line-height: 1.35;
}

.mira-map-list__text small {
  display: block;
  font-size: 0.78rem;
  color: var(--soft-gray);
  margin-top: 0.2rem;
  line-height: 1.35;
}

.mira-map-list__chev {
  color: rgba(60, 48, 38, 0.25);
  font-size: 1rem;
}

/* Mira Road — society cards (below map) */
.mira-societies-showcase {
  background: #faf7f2;
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.mira-societies-showcase__title {
  font-family: "Abril Fatface", serif;
  color: var(--dark-black);
  font-size: 1.85rem;
  margin-bottom: 1rem;
}

.mira-societies-showcase__lead {
  font-size: 1.05rem;
  line-height: 1.75;
  color: #4a4238;
  margin-bottom: 0.75rem;
}

.mira-societies-showcase__hint {
  font-size: 0.92rem;
}

.mira-soc-card {
  height: 100%;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(212, 175, 55, 0.22);
  box-shadow: 0 14px 40px rgba(45, 33, 24, 0.08);
  transition:
    box-shadow 0.25s ease,
    border-color 0.25s ease,
    transform 0.2s ease;
}

.mira-soc-card:hover {
  box-shadow: 0 20px 50px rgba(45, 33, 24, 0.12);
  transform: translateY(-2px);
}

.mira-soc-card.is-active {
  border-color: var(--primary-gold);
  box-shadow: 0 0 0 2px rgba(212, 175, 55, 0.35), 0 18px 48px rgba(45, 33, 24, 0.12);
}

.mira-soc-card__img-wrap {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: #e8e0d4;
}

.mira-soc-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mira-soc-card__body {
  padding: 1.15rem 1.2rem 1.25rem;
}

.mira-soc-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark-black);
  line-height: 1.35;
  margin-bottom: 0.35rem;
}

.mira-soc-card__sub {
  font-size: 0.8rem;
  color: var(--soft-gray);
  line-height: 1.45;
  margin-bottom: 0.65rem;
}

.mira-soc-card__txt {
  font-size: 0.9rem;
  line-height: 1.6;
  color: #4a4238;
  margin-bottom: 1rem;
}

.mira-soc-card__map-btn {
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 8px 14px !important;
}

.mira-societies-footnote {
  margin-top: 2rem;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.55;
}

.mira-map-strip {
  background: linear-gradient(135deg, #231913 0%, #3b2a1d 100%);
  color: #f8f1e7;
  border-radius: 0;
}

.mira-map-strip h2 {
  color: var(--primary-gold);
  font-family: "Abril Fatface", serif;
}

.mira-map-strip p {
  color: rgba(248, 241, 231, 0.85);
}

/* Google Maps InfoWindow */
.mira-map-info {
  max-width: 260px;
  padding: 4px 2px 6px;
  font-family: "Roboto", Arial, sans-serif;
}

.mira-map-info strong {
  display: block;
  font-size: 1rem;
  color: #1c1c1c;
  margin-bottom: 0.25rem;
}

.mira-map-info span {
  display: block;
  font-size: 0.78rem;
  color: #6a6258;
  margin-bottom: 0.65rem;
}

.mira-map-info p {
  font-size: 0.88rem;
  line-height: 1.55;
  color: #444;
  margin: 0 0 0.75rem;
}

.mira-map-info a {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 600;
  color: #b8860b !important;
}

.mira-map-info__brand {
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  color: #8a6d1d;
  margin: 0 0 0.65rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(212, 175, 55, 0.35);
}

@media (max-width: 991.98px) {
  .mira-map-explorer {
    padding-top: 1.5rem;
  }

  .mira-map-sidebar {
    min-height: auto;
    margin-bottom: 1.25rem;
  }

  .mira-map-theatre {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .mira-map-theatre__glass {
    min-height: auto;
    margin-top: 1rem;
  }

  .mira-map-frame--theatre {
    min-height: auto;
  }

  .mira-map-frame--theatre .mira-road-map-canvas,
  .mira-map-frame--theatre .mira-map-fallback-iframe {
    height: 55vh;
    min-height: 360px;
  }

  .mira-map-theatre__glass .mira-map-list {
    max-height: 320px;
  }

  .mira-map-list {
    max-height: 320px;
  }

  .mira-road-map-canvas {
    height: 55vh;
    min-height: 360px;
  }

  .mira-corridor-chips__row {
    flex-direction: column;
    align-items: flex-start;
  }

  .mira-corridor-chips {
    width: 100%;
  }
}

/* ========== Founder story page (Bhartik Yadav) ========== */
body.founder-story-page .founder-story-page__eyebrow {
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 0.5rem;
}

body.founder-story-page .founder-story-page__header h2 {
  font-family: "Abril Fatface", serif;
  color: var(--dark-black);
  line-height: 1.25;
}

.founder-story-page__kicker {
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--terracotta);
  margin-bottom: 0.75rem;
}

.founder-story-page__lead {
  font-size: 1.08rem;
  line-height: 1.75;
  color: var(--soft-gray);
  max-width: 40rem;
  margin: 0 auto;
}

.founder-story-page__portrait {
  border-radius: 24px;
  aspect-ratio: 4 / 5;
  max-height: 520px;
  background-size: cover;
  background-position: center top;
  box-shadow: 0 28px 60px rgba(25, 18, 13, 0.15);
  border: 1px solid rgba(212, 175, 55, 0.25);
}

.founder-story-page__quote {
  margin: 1.75rem 0 0;
  padding: 1.25rem 1.5rem;
  border-left: 4px solid var(--primary-gold);
  background: rgba(212, 175, 55, 0.08);
  border-radius: 0 12px 12px 0;
}

.founder-story-page__quote p {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--dark-black);
  margin-bottom: 0.5rem;
  font-style: italic;
}

.founder-story-page__quote cite {
  font-size: 0.88rem;
  color: var(--soft-gray);
  font-style: normal;
}

.founder-story-page__band {
  background: linear-gradient(135deg, #231913 0%, #3b2a1d 100%);
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.founder-story-page__stat strong {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary-gold);
  font-family: "Roboto", sans-serif;
  margin-bottom: 0.35rem;
}

.founder-story-page__stat span {
  display: block;
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  color: rgba(248, 241, 231, 0.82);
  text-transform: uppercase;
}

.founder-story-page__list {
  padding-left: 1.25rem;
  color: var(--soft-gray);
}

.founder-story-page__list li {
  margin-bottom: 0.65rem;
}

.founder-story-page__cta-box {
  padding: 2rem 1.75rem;
  border-radius: 20px;
  background: linear-gradient(180deg, #fbf9f4 0%, #f0e8dc 100%);
  border: 1px solid rgba(212, 175, 55, 0.3);
  box-shadow: 0 16px 40px rgba(25, 18, 13, 0.08);
}

.founder-story-page__content {
  overflow: hidden;
}

.founder-story-page__story-row {
  margin: 0;
  padding: 22px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(246, 238, 224, 0.95) 100%);
  border: 1px solid rgba(166, 122, 72, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.founder-story-page__story-row + .founder-story-page__story-row {
  margin-top: 28px;
}

.founder-story-page__story-copy {
  padding-right: 8px;
}

.founder-story-page__story-tag {
  display: inline-flex;
  align-items: center;
  margin-bottom: 0.9rem;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: rgba(212, 175, 55, 0.14);
  color: var(--terracotta);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.founder-story-page__story-copy h2 {
  line-height: 1.3;
}

.founder-story-page__story-copy p,
.founder-story-page__story-copy li {
  font-size: 1.02rem;
  line-height: 1.85;
}

.founder-story-page__story-media {
  margin: 0;
  min-height: 280px;
  height: 100%;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(166, 122, 72, 0.14);
  box-shadow: 0 20px 44px rgba(43, 29, 20, 0.14);
  background: #f8f1e7;
}

.founder-story-page__story-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
}

.founder-story-page__story-media--recognition {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: linear-gradient(180deg, #fff 0%, #f8f1e7 100%);
}

.founder-story-page__story-media--recognition img {
  min-height: 0;
  height: auto;
  max-height: 260px;
  object-fit: contain;
}

.founder-story-page__story-list {
  margin-bottom: 0;
}

.founder-story-page__story-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.founder-story-page__story-gallery img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid rgba(166, 122, 72, 0.12);
  box-shadow: 0 18px 36px rgba(43, 29, 20, 0.12);
}

body.founder-story-page .interior-article a {
  font-weight: 600;
}

body.founder-story-page .founder-story-page__back .btn-custom {
  display: inline-flex;
  align-items: center;
}

body.site-shell .staff .text h3 a {
  color: inherit;
  text-decoration: none;
}

body.site-shell .staff .text h3 a:hover {
  color: var(--primary-gold);
}

@media (max-width: 991.98px) {
  .founder-story-page__story-copy {
    padding-right: 0;
    padding-bottom: 1rem;
  }

  .founder-story-page__story-row {
    padding: 20px;
  }
}

@media (max-width: 767.98px) {
  .founder-story-page__portrait {
    max-height: 420px;
    margin: 0 auto;
    max-width: 360px;
  }

  .founder-story-page__content {
    padding: 24px;
  }

  .founder-story-page__story-row {
    padding: 16px;
    border-radius: 22px;
  }

  .founder-story-page__story-media {
    min-height: 220px;
  }

  .founder-story-page__story-media img {
    min-height: 220px;
  }

  .founder-story-page__story-media--recognition img {
    min-height: 0;
  }
}

body.site-shell .navbar-brand.site-brand {
  display: inline-flex;
  align-items: center;
  max-width: min(250px, calc(100% - 96px));
  margin-right: 16px;
  padding-top: 0;
  padding-bottom: 0;
  font-family: inherit;
  letter-spacing: 0;
}

body.site-shell .site-brand__logo {
  display: block;
  width: auto;
  height: 56px;
  max-width: 100%;
  filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.28));
  transform-origin: center left;
  will-change: transform, opacity;
  backface-visibility: hidden;
  animation: brand-logo-fly-in 0.88s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
}

@keyframes brand-logo-fly-in {
  0% {
    opacity: 0;
    transform: translate3d(-38px, -8px, 0) scale(0.84) rotate(-5deg);
  }
  62% {
    opacity: 1;
    transform: translate3d(6px, 0, 0) scale(1.03) rotate(1deg);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
}

body.site-shell .home-slider .slider-item.hero-slide {
  background-position: center center !important;
}

body.site-shell .home-slider .slider-item.hero-slide .overlay {
  background: linear-gradient(90deg, rgba(10, 8, 7, 0.9) 0%, rgba(19, 14, 10, 0.76) 34%, rgba(30, 22, 16, 0.34) 68%, rgba(30, 22, 16, 0.12) 100%);
  opacity: 1;
}

body.site-shell .home-slider .hero-text {
  max-width: 680px;
  padding-right: 32px;
}

body.site-shell .home-slider .hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.78);
}

body.site-shell .home-slider .hero-kicker::before {
  content: "";
  width: 56px;
  height: 1px;
  background: rgba(212, 175, 55, 0.72);
}

body.site-shell .home-slider .hero-story {
  margin-bottom: 24px;
  max-width: 38ch;
  font-size: 17px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.86);
}

body.site-shell .home-slider .hero-text h1 {
  max-width: 10ch;
  margin-bottom: 16px;
  color: #ffffff;
  font-size: 62px;
  line-height: 1.02;
  letter-spacing: 0;
  text-transform: none;
}

body.site-shell .home-slider .hero-lead {
  max-width: 34ch;
  margin-bottom: 0;
  font-size: 18px;
  line-height: 1.68;
  color: rgba(255, 255, 255, 0.88);
}

body.site-shell .home-slider .hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 26px 0 30px;
  padding: 0;
  list-style: none;
}

body.site-shell .home-slider .hero-proof li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(255, 255, 255, 0.9);
}

body.site-shell .home-slider .hero-proof li i {
  color: #d4af37;
  font-size: 0.95rem;
}

body.site-shell .home-slider .hero-actions {
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 12px;
  margin-top: 28px;
  padding: 12px 14px;
  width: fit-content;
  max-width: 100%;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 22px 44px rgba(10, 8, 7, 0.24);
  backdrop-filter: blur(16px);
}

body.site-shell .home-slider .hero-icon-link {
  --hero-icon-accent: #d4af37;
  position: relative;
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.05) 100%);
  box-shadow:
    0 16px 32px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  color: #ffffff;
  text-decoration: none;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

body.site-shell .home-slider .hero-icon-link::after {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 14px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.6;
  pointer-events: none;
}

body.site-shell .home-slider .hero-icon-link i {
  position: relative;
  z-index: 1;
  font-size: 1.15rem;
  color: var(--hero-icon-accent);
}

body.site-shell .home-slider .hero-icon-link:hover,
body.site-shell .home-slider .hero-icon-link:focus {
  transform: translateY(-3px);
  border-color: rgba(255, 255, 255, 0.3);
  box-shadow:
    0 20px 36px rgba(0, 0, 0, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  color: #ffffff;
  text-decoration: none;
}

body.site-shell .home-slider .hero-icon-link--whatsapp {
  --hero-icon-accent: #25d366;
}

body.site-shell .home-slider .hero-icon-link--youtube {
  --hero-icon-accent: #ff3b30;
}

body.site-shell .home-slider .hero-icon-link--call {
  --hero-icon-accent: #f4ede3;
}

body.site-shell .home-slider .hero-icon-link--reviews {
  --hero-icon-accent: #4285f4;
}

body.site-shell .home-slider .hero-icon-link--gallery {
  --hero-icon-accent: #d4af37;
}

body.site-shell .home-slider .hero-text {
  padding-top: 16px;
}

body.site-shell .home-slider .hero-lead {
  margin-bottom: 0;
}

@media (max-width: 991.98px) {
  body.site-shell .navbar-brand.site-brand {
    max-width: calc(100% - 92px);
  }

  body.site-shell .site-brand__logo {
    height: 48px;
  }

  body.site-shell .home-slider .slider-item.hero-slide {
    background-position: 56% center !important;
  }

  body.site-shell .home-slider .hero-text {
    max-width: 520px;
    padding-right: 0;
  }

  body.site-shell .home-slider .hero-text h1 {
    font-size: 50px;
  }
}

@media (max-width: 767.98px) {
  body.site-shell .site-brand__logo {
    height: 42px;
  }

  body.site-shell .home-slider .slider-item.hero-slide {
    background-position: 58% center !important;
  }

  body.site-shell .home-slider .hero-text {
    max-width: none;
    text-align: left;
  }

  body.site-shell .home-slider .hero-kicker {
    font-size: 0.7rem;
    letter-spacing: 0.12em;
  }

  body.site-shell .home-slider .hero-kicker::before {
    width: 34px;
  }

  body.site-shell .home-slider .hero-text h1 {
    max-width: 10ch;
    font-size: 34px;
  }

  body.site-shell .home-slider .hero-lead {
    max-width: 28ch;
    font-size: 15px;
    line-height: 1.65;
  }

  body.site-shell .home-slider .hero-actions {
    gap: 8px;
    padding: 10px;
  }

  body.site-shell .home-slider .hero-icon-link {
    flex-basis: 46px;
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }

  body.site-shell .home-slider .hero-icon-link::after {
    inset: 8px;
  }

  body.site-shell .home-slider .hero-icon-link i {
    font-size: 1rem;
  }

  body.site-shell .home-slider .hero-proof {
    gap: 10px;
    margin: 20px 0 26px;
  }

  body.site-shell .home-slider .hero-proof li {
    padding: 9px 14px;
    font-size: 0.76rem;
  }
}

@media (max-width: 575.98px) {
  body.site-shell .home-slider .hero-actions {
    justify-content: flex-start;
  }
}

body.site-shell #ftco-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 20000;
  background:
    linear-gradient(180deg, #fdf9f3 0%, #f4ebde 100%);
}

body.site-shell #ftco-loader.fullscreen {
  padding: 24px;
}

body.site-shell #ftco-loader .brand-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  width: min(320px, 72vw);
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.32s ease, transform 0.32s ease;
}

body.site-shell #ftco-loader .brand-loader__logo {
  display: block;
  width: min(280px, 100%);
  height: auto;
  filter: drop-shadow(0 18px 30px rgba(25, 18, 13, 0.12));
  animation: brand-loader-float 1.8s ease-in-out infinite;
}

body.site-shell #ftco-loader .brand-loader__line {
  position: relative;
  display: block;
  width: min(140px, 46vw);
  height: 4px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(28, 28, 28, 0.08);
}

body.site-shell #ftco-loader .brand-loader__line::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(212, 175, 55, 0.12) 0%, #d4af37 48%, rgba(212, 175, 55, 0.12) 100%);
  transform: translateX(-100%);
  animation: brand-loader-sweep 1.2s ease-in-out infinite;
}

body.site-shell #ftco-loader:not(.show) .brand-loader {
  opacity: 0;
  transform: translateY(10px);
}

@keyframes brand-loader-float {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

@keyframes brand-loader-sweep {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

@media (max-width: 767.98px) {
  body.site-shell #ftco-loader .brand-loader {
    width: min(260px, 76vw);
    gap: 18px;
  }
}

/* ============================================
   LOGO-LED BRAND REFRESH
   ============================================ */

:root {
  --primary-gold: #d8b56f;
  --light-gold: #f0d9a3;
  --accent-gold: #fff0c6;
  --dark-black: #241914;
  --charcoal: #3d2d22;
  --forest-green: #30241c;
  --dark-slate: #5a4331;
  --terracotta: #a67a48;
  --cream: #fff9ef;
  --soft-gray: #6f5b49;
  --nav-wood-base: #fff8ed;
  --nav-wood-edge: rgba(168, 122, 72, 0.22);
  --nav-wood-shadow: rgba(43, 29, 20, 0.12);
  --brand-ivory: #fffdf8;
  --brand-sand: #f7ecd7;
  --brand-mist: #efdec0;
  --brand-shadow: rgba(43, 29, 20, 0.1);
  --brand-shadow-strong: rgba(43, 29, 20, 0.2);
  --brand-glow: rgba(216, 181, 111, 0.24);
  --surface-shadow-soft: 0 14px 34px rgba(43, 29, 20, 0.07), 0 5px 14px rgba(43, 29, 20, 0.04);
  --surface-shadow-card: 0 24px 58px rgba(43, 29, 20, 0.1), 0 10px 24px rgba(43, 29, 20, 0.05);
  --surface-shadow-card-hover: 0 34px 74px rgba(32, 21, 15, 0.14), 0 14px 30px rgba(32, 21, 15, 0.07);
  --surface-shadow-hero: 0 42px 100px rgba(25, 18, 13, 0.18), 0 16px 36px rgba(25, 18, 13, 0.08);
  --surface-highlight: inset 0 1px 0 rgba(255, 255, 255, 0.78), inset 0 -1px 0 rgba(255, 255, 255, 0.18);
  --glass-stroke: rgba(255, 255, 255, 0.3);
}

body.site-shell {
  background:
    radial-gradient(circle at top right, rgba(240, 217, 163, 0.3) 0%, transparent 24%),
    radial-gradient(circle at 12% 16%, rgba(255, 255, 255, 0.66) 0%, transparent 16%),
    radial-gradient(circle at left 78%, rgba(216, 181, 111, 0.12) 0%, transparent 20%),
    linear-gradient(180deg, #fffdfa 0%, #fbf4e8 40%, #f2e7d4 100%);
  color: var(--dark-black);
}

body.site-shell .ftco-section,
body.site-shell .cta-section,
body.site-shell .project-lens,
body.site-shell .ftco-footer,
body.site-shell .collection-hero,
body.site-shell .mira-simple-hero,
body.site-shell .inquiry-planner-hero,
body.site-shell .mira-map-hero {
  position: relative;
}

.page-intro .subheading,
.site-shell .article-eyebrow,
.inquiry-planner-hero__kicker,
.mira-map-hero__eyebrow,
.collection-hero__eyebrow,
.mira-simple-hero__eyebrow {
  border: 1px solid rgba(166, 122, 72, 0.18);
  border-radius: 999px;
  padding: 0.7rem 1rem;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.82) 0%, rgba(246, 232, 201, 0.82) 100%);
  box-shadow: 0 10px 24px rgba(43, 29, 20, 0.06);
  color: var(--terracotta);
}

body.site-shell #ftco-navbar,
body.site-shell #ftco-navbar.ftco-navbar-light,
body.site-shell #ftco-navbar.ftco-navbar-light.scrolled,
body.site-shell #ftco-navbar.ftco-navbar-light.scrolled.awake,
body.site-shell #ftco-navbar.ftco-navbar-light.scrolled.sleep,
body.site-shell .ftco-navbar-light,
body.site-shell .ftco-navbar-light.scrolled,
body.site-shell .ftco-navbar-light.scrolled.awake,
body.site-shell .ftco-navbar-light.scrolled.sleep {
  background-color: #1f1510 !important;
  background-image:
    radial-gradient(circle at top right, rgba(240, 217, 163, 0.2) 0%, transparent 26%),
    linear-gradient(135deg, rgba(24, 17, 13, 0.9) 0%, rgba(44, 31, 23, 0.92) 46%, rgba(31, 21, 16, 0.9) 100%) !important;
  box-shadow:
    0 18px 44px rgba(17, 11, 8, 0.18),
    0 8px 18px rgba(17, 11, 8, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 -1px 0 rgba(216, 181, 111, 0.14) !important;
  border-bottom: 1px solid rgba(216, 181, 111, 0.2) !important;
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
}

body.site-shell #ftco-navbar.ftco-navbar-light.scrolled::before {
  height: 1px;
  top: auto;
  bottom: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.08), rgba(216, 181, 111, 0.72), rgba(255, 255, 255, 0));
}

body.site-shell .ftco-navbar-light .navbar-brand,
body.site-shell .ftco-navbar-light.scrolled .navbar-brand,
body.site-shell .navbar-brand {
  color: var(--light-gold) !important;
}

body.site-shell .site-brand__logo {
  filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.16));
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link,
body.site-shell .ftco-navbar-light.scrolled .nav-link,
body.site-shell .navbar-nav .nav-link {
  color: rgba(255, 246, 230, 0.88) !important;
  border: 1px solid transparent;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 100%);
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease, color 0.24s ease;
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover,
body.site-shell .ftco-navbar-light .navbar-nav > .nav-item.active > a,
body.site-shell .ftco-navbar-light.scrolled .nav-link.active,
body.site-shell .navbar-nav .nav-link.active {
  color: var(--light-gold) !important;
  transform: translateY(-1px);
  border-color: rgba(240, 217, 163, 0.14);
  background: linear-gradient(135deg, rgba(244, 222, 171, 0.18) 0%, rgba(201, 153, 68, 0.1) 100%);
  box-shadow: 0 16px 32px rgba(20, 13, 9, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body.site-shell .ftco-navbar-light .navbar-toggler,
body.site-shell .ftco-navbar-light.scrolled .navbar-toggler,
body.site-shell .navbar-dark .navbar-toggler {
  color: rgba(255, 246, 230, 0.92) !important;
  border-color: rgba(216, 181, 111, 0.16) !important;
}

body.site-shell .home-slider .slider-item.hero-slide {
  background-color: #2f221a;
}

body.site-shell .home-slider .slider-item.hero-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 76% 24%, rgba(240, 217, 163, 0.2) 0%, transparent 24%),
    radial-gradient(circle at 22% 72%, rgba(216, 181, 111, 0.18) 0%, transparent 26%);
  pointer-events: none;
}

body.site-shell .home-slider .slider-item.hero-slide .overlay,
body.site-shell .home-slider .slider-item .overlay {
  background:
    linear-gradient(104deg, rgba(20, 14, 11, 0.92) 0%, rgba(36, 25, 20, 0.78) 34%, rgba(74, 53, 37, 0.38) 72%, rgba(74, 53, 37, 0.16) 100%);
}

body.site-shell .home-slider .hero-kicker,
body.site-shell .home-slider .hero-lead,
body.site-shell .home-slider .slider-text p,
body.site-shell .home-slider .slider-text .breadcrumbs span,
body.site-shell .home-slider .slider-text .breadcrumbs span a {
  color: rgba(255, 248, 236, 0.92);
}

body.site-shell .home-slider .hero-text h1,
body.site-shell .inquiry-planner-hero__title,
body.site-shell .mira-map-hero__title,
body.site-shell .mira-simple-hero__title,
body.site-shell .collection-hero h1 {
  text-shadow: 0 12px 28px rgba(15, 10, 7, 0.24);
}

body.site-shell .home-slider .hero-proof li,
body.site-shell .project-lens__metrics span,
body.site-shell .story-meta span,
body.site-shell .mira-map-hero__stats li {
  border: 1px solid rgba(240, 217, 163, 0.24);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.14) 0%, rgba(240, 217, 163, 0.1) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(14px);
}

body.site-shell .btn-gold,
body.site-shell .btn-green,
body.site-shell .btn-primary,
body.site-shell input[type="submit"] {
  position: relative;
  overflow: hidden;
  border-width: 1px !important;
  box-shadow: var(--surface-shadow-soft);
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, filter 0.24s ease;
}

body.site-shell .btn-gold,
body.site-shell .btn-primary,
body.site-shell input[type="submit"] {
  background: linear-gradient(135deg, #f4deab 0%, #ddb972 40%, #c99944 100%) !important;
  border-color: rgba(167, 122, 72, 0.24) !important;
  color: var(--dark-black) !important;
}

body.site-shell .btn-gold::after,
body.site-shell .btn-green::after,
body.site-shell .btn-primary::after,
body.site-shell input[type="submit"]::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  top: 1px;
  height: 44%;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0));
  pointer-events: none;
}

body.site-shell .btn-green {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92) 0%, rgba(247, 236, 214, 0.94) 100%);
  border-color: rgba(167, 122, 72, 0.18);
  color: var(--dark-black);
}

body.site-shell .btn-gold:hover,
body.site-shell .btn-gold:focus,
body.site-shell .btn-primary:hover,
body.site-shell .btn-primary:focus,
body.site-shell input[type="submit"]:hover,
body.site-shell input[type="submit"]:focus,
body.site-shell .btn-green:hover,
body.site-shell .btn-green:focus {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px rgba(43, 29, 20, 0.16), 0 10px 22px rgba(216, 181, 111, 0.12);
  filter: saturate(1.02);
}

body.site-shell .services,
body.site-shell .staff,
body.site-shell .blog-entry,
body.site-shell .story-card .text,
body.site-shell .testimony-wrap,
body.site-shell .project-note,
body.site-shell .contact-card,
body.site-shell .contact-panel,
body.site-shell .sidebar-panel,
body.site-shell .interior-article,
.project-lens__content,
.services-page .service-feature-card,
.collection-hero__content,
.pi-wizard,
.gallery-status,
.mira-map-sidebar,
.mira-map-presence {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(254, 251, 245, 0.94) 52%, rgba(247, 238, 223, 0.92) 100%);
  border: 1px solid rgba(166, 122, 72, 0.14);
  box-shadow: var(--surface-shadow-card), var(--surface-highlight);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

body.site-shell .staff {
  border-radius: 22px;
  overflow: hidden;
  height: 100%;
}

body.site-shell .staff .img {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}

body.site-shell .staff .text {
  padding: 1.5rem 1.4rem 1.7rem;
}

body.site-shell .staff .text p {
  margin-bottom: 0;
}

body.site-shell .services:hover,
body.site-shell .staff:hover,
body.site-shell .blog-entry:hover,
body.site-shell .testimony-wrap:hover,
body.site-shell .project-note:hover,
body.site-shell .contact-card:hover,
body.site-shell .contact-panel:hover,
body.site-shell .sidebar-panel:hover,
body.site-shell .story-card:hover .text {
  transform: translateY(-6px);
  border-color: rgba(166, 122, 72, 0.22);
  box-shadow: var(--surface-shadow-card-hover), inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

body.site-shell .services .icon,
body.site-shell .ftco-services .services .icon,
body.site-shell .project .icon,
.mira-map-hero__card-pin,
.project-lens__zoom {
  background: linear-gradient(135deg, #f4deab 0%, #d8b56f 46%, #bf9343 100%);
  box-shadow: 0 16px 36px rgba(216, 181, 111, 0.22);
}

body.site-shell .services .icon span,
body.site-shell .ftco-services .services .icon span,
body.site-shell .project .icon span,
.project-lens__zoom {
  color: var(--dark-black) !important;
}

body.site-shell .project,
body.site-shell .story-card .block-20,
body.site-shell .interior-article .img-fluid,
.project-lens__media {
  border: 1px solid rgba(166, 122, 72, 0.12);
  box-shadow: var(--surface-shadow-card);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

body.site-shell .project:hover,
body.site-shell .story-card:hover .block-20,
body.site-shell .interior-article:hover .img-fluid,
.project-lens:hover .project-lens__media {
  transform: translateY(-4px);
  border-color: rgba(166, 122, 72, 0.2);
  box-shadow: var(--surface-shadow-card-hover);
}

body.site-shell .project .text {
  background: linear-gradient(180deg, rgba(29, 20, 15, 0.06) 0%, rgba(29, 20, 15, 0.84) 100%);
}

body.site-shell .cta-section,
.project-lens,
body.site-shell .ftco-footer,
.inquiry-planner-hero,
.mira-map-hero,
.collection-hero,
.mira-simple-hero {
  overflow: hidden;
  border: 1px solid rgba(216, 181, 111, 0.16);
  box-shadow: var(--surface-shadow-hero);
}

body.site-shell .cta-section,
.project-lens,
.inquiry-planner-hero,
.mira-map-hero,
.collection-hero,
.mira-simple-hero {
  background:
    radial-gradient(circle at top right, rgba(240, 217, 163, 0.22), transparent 30%),
    radial-gradient(circle at left bottom, rgba(216, 181, 111, 0.16), transparent 24%),
    linear-gradient(135deg, #2b1f18 0%, #4b3526 48%, #241914 100%);
}

body.site-shell .cta-section::before,
.project-lens::before,
.inquiry-planner-hero::before,
.mira-map-hero::before,
.collection-hero::before,
.mira-simple-hero::before,
body.site-shell .ftco-footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.4), rgba(240, 217, 163, 0.68), rgba(255, 255, 255, 0));
  pointer-events: none;
}

body.site-shell .cta-section h2,
body.site-shell .cta-section h3,
body.site-shell .ftco-footer h2,
body.site-shell .ftco-footer .ftco-heading-2,
.inquiry-planner-hero__title span,
.mira-map-hero__title span,
.collection-hero__eyebrow,
.mira-simple-hero__title span {
  color: var(--light-gold);
}

body.site-shell .cta-section p,
body.site-shell .ftco-footer p,
body.site-shell .ftco-footer a,
.collection-hero p,
.mira-simple-hero p,
.inquiry-planner-hero__lead,
.mira-map-hero__lead,
.mira-map-hero__stats span {
  color: rgba(255, 248, 236, 0.86);
}

body.site-shell .ftco-footer {
  background:
    radial-gradient(circle at top right, rgba(240, 217, 163, 0.14), transparent 28%),
    linear-gradient(135deg, #1e140f 0%, #36261c 42%, #1a110d 100%);
}

body.site-shell .footer-small-nav > li a,
body.site-shell .ftco-footer a:hover {
  color: var(--light-gold);
}

body.site-shell .contact-panel .form-control,
body.site-shell .translate-cta__panel,
body.site-shell .translate-cta__widget .goog-te-gadget-simple,
.mira-map-search,
.mira-map-reset {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(250, 243, 231, 0.94) 100%) !important;
  border-color: rgba(166, 122, 72, 0.16) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

body.site-shell .contact-panel .form-control:focus,
.mira-map-search:focus {
  border-color: rgba(216, 181, 111, 0.42) !important;
  box-shadow: 0 0 0 4px rgba(216, 181, 111, 0.12) !important;
}

body.site-shell .contact-option {
  background: linear-gradient(135deg, rgba(255, 251, 244, 0.96) 0%, rgba(240, 217, 163, 0.94) 100%);
  color: var(--floating-icon-color);
  border: 1px solid rgba(166, 122, 72, 0.18);
  box-shadow: 0 18px 32px rgba(43, 29, 20, 0.12);
}

body.site-shell .contact-option.call {
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.98) 0%, rgba(219, 234, 254, 0.96) 100%);
  border-color: rgba(15, 98, 255, 0.3);
  box-shadow:
    0 18px 32px rgba(43, 29, 20, 0.12),
    0 10px 24px rgba(15, 98, 255, 0.16);
}

body.site-shell .contact-option:hover,
body.site-shell .contact-option:focus {
  background: linear-gradient(135deg, #f7e4b7 0%, #d8b56f 100%);
  color: var(--dark-black);
}

body.site-shell .translate-cta__toggle {
  background: linear-gradient(135deg, rgba(255, 251, 244, 0.96) 0%, rgba(240, 217, 163, 0.94) 100%);
  color: var(--dark-black);
  border: 1px solid rgba(166, 122, 72, 0.18);
  box-shadow: 0 18px 32px rgba(43, 29, 20, 0.12);
}

body.site-shell .translate-cta__toggle:hover,
body.site-shell .translate-cta__toggle:focus {
  background: linear-gradient(135deg, #f7e4b7 0%, #d8b56f 100%);
  color: var(--dark-black);
}

@media (max-width: 991.98px) {
  body.site-shell #ftco-navbar,
  body.site-shell #ftco-navbar.ftco-navbar-light,
  body.site-shell #ftco-navbar.ftco-navbar-light.scrolled,
  body.site-shell .ftco-navbar-light,
  body.site-shell .ftco-navbar-light.scrolled {
    background-color: #1f1510 !important;
    background-image:
      radial-gradient(circle at top right, rgba(240, 217, 163, 0.18) 0%, transparent 28%),
      linear-gradient(135deg, rgba(24, 17, 13, 0.99) 0%, rgba(48, 34, 24, 0.98) 50%, rgba(31, 21, 16, 0.98) 100%) !important;
  }

  body.site-shell #ftco-nav.navbar-collapse.collapse.show,
  body.site-shell #ftco-nav.navbar-collapse.collapsing {
    background-color: #241914 !important;
    background-image:
      radial-gradient(circle at top right, rgba(240, 217, 163, 0.14) 0%, transparent 24%),
      linear-gradient(180deg, rgba(36, 25, 20, 0.99) 0%, rgba(49, 35, 25, 0.98) 100%) !important;
    border-top: 1px solid rgba(216, 181, 111, 0.18);
    box-shadow: 0 24px 54px rgba(17, 11, 8, 0.28);
  }

  body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link,
  body.site-shell .ftco-navbar-light.scrolled .nav-link,
  body.site-shell .navbar-nav .nav-link {
    color: rgba(255, 246, 230, 0.88) !important;
    border-bottom-color: rgba(216, 181, 111, 0.12);
  }

  body.site-shell .home-slider .hero-proof li {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.18) 0%, rgba(240, 217, 163, 0.14) 100%);
  }
}

body.site-shell .youtube-wall-section {
  padding-top: 4.2rem;
  padding-bottom: 4.8rem;
}

body.site-shell .youtube-wall-shell {
  padding: clamp(1.2rem, 2vw, 2rem);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(197, 54, 44, 0.14) 0%, transparent 24%),
    linear-gradient(145deg, #17100d 0%, #241814 52%, #17100d 100%);
  border: 1px solid rgba(216, 181, 111, 0.16);
  box-shadow:
    0 30px 76px rgba(17, 11, 8, 0.22),
    0 14px 28px rgba(17, 11, 8, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body.site-shell .youtube-wall-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.4rem;
}

body.site-shell .youtube-wall-head__title {
  min-width: 0;
}

body.site-shell .youtube-wall-head__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.45rem;
  color: rgba(255, 245, 230, 0.82);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body.site-shell .youtube-wall-head__eyebrow i {
  color: #ff6c57;
}

body.site-shell .youtube-wall-head h2 {
  margin: 0;
  color: #fff7ea;
  font-size: clamp(1.5rem, 2.2vw, 2.2rem);
}

body.site-shell .youtube-wall-head__cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(216, 181, 111, 0.22);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(240, 217, 163, 0.08) 100%);
  color: var(--light-gold);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  box-shadow: 0 14px 28px rgba(11, 7, 5, 0.16);
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

body.site-shell .youtube-wall-head__cta:hover,
body.site-shell .youtube-wall-head__cta:focus {
  transform: translateY(-2px);
  color: #1f1510;
  background: linear-gradient(135deg, #f4deab 0%, #ddb972 40%, #c99944 100%);
  box-shadow: 0 18px 32px rgba(11, 7, 5, 0.2);
}

body.site-shell .youtube-wall-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.site-shell .youtube-wall-card {
  display: block;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(216, 181, 111, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 100%);
  box-shadow:
    0 22px 48px rgba(11, 7, 5, 0.18),
    0 8px 20px rgba(11, 7, 5, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  transition:
    transform 0.24s ease,
    border-color 0.24s ease,
    box-shadow 0.24s ease;
}

body.site-shell .youtube-wall-card:hover,
body.site-shell .youtube-wall-card:focus {
  transform: translateY(-5px);
  border-color: rgba(216, 181, 111, 0.28);
  box-shadow:
    0 30px 60px rgba(11, 7, 5, 0.24),
    0 12px 24px rgba(11, 7, 5, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body.site-shell .youtube-wall-card__media {
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #0f0a08;
}

body.site-shell .youtube-wall-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 7, 5, 0.04) 0%, rgba(10, 7, 5, 0.4) 100%);
}

body.site-shell .youtube-wall-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.36s ease;
}

body.site-shell .youtube-wall-card:hover .youtube-wall-card__media img,
body.site-shell .youtube-wall-card:focus .youtube-wall-card__media img {
  transform: scale(1.05);
}

body.site-shell .youtube-wall-card__badge {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 1;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ff6c57 0%, #c0392b 100%);
  color: #fff;
  box-shadow: 0 12px 24px rgba(192, 57, 43, 0.3);
}

body.site-shell .youtube-wall-card__title {
  display: block;
  padding: 0.85rem 0.95rem 1rem;
  color: rgba(255, 246, 234, 0.9);
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.45;
}

@media (max-width: 991.98px) {
  body.site-shell .youtube-wall-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  body.site-shell .youtube-wall-section {
    padding-top: 3.2rem;
    padding-bottom: 3.4rem;
  }

  body.site-shell .youtube-wall-shell {
    padding: 1rem;
    border-radius: 24px;
  }

  body.site-shell .youtube-wall-head {
    align-items: flex-start;
    flex-direction: column;
  }

  body.site-shell .youtube-wall-head__cta {
    width: 100%;
  }

  body.site-shell .youtube-wall-grid {
    gap: 14px;
  }

  body.site-shell .youtube-wall-card {
    border-radius: 18px;
  }

  body.site-shell .youtube-wall-card__title {
    font-size: 0.84rem;
    padding: 0.75rem 0.8rem 0.9rem;
  }
}

body.site-shell .home-slider .slider-item.hero-slide .overlay {
  display: block;
  background: linear-gradient(96deg, rgba(12, 10, 9, 0.74) 0%, rgba(24, 18, 14, 0.58) 34%, rgba(40, 30, 22, 0.28) 66%, rgba(255, 248, 236, 0.08) 100%);
  opacity: 1;
}

body.site-shell .home-slider .hero-text h1 {
  text-shadow: 0 20px 34px rgba(0, 0, 0, 0.24);
}

body.site-shell .home-slider .hero-lead,
body.site-shell .home-slider .hero-kicker {
  text-shadow: 0 12px 22px rgba(0, 0, 0, 0.18);
}

body.site-shell .navbar-nav > .nav-item {
  margin-left: 6px;
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link,
body.site-shell .ftco-navbar-light.scrolled .nav-link,
body.site-shell .navbar-nav .nav-link {
  font-family: 'Abril Fatface', serif;
  font-size: 0.98rem;
  line-height: 1.08;
  letter-spacing: 0.04em;
  text-transform: none;
  padding: 0.56rem 0.84rem !important;
  border-radius: 999px;
  text-shadow: 0 10px 22px rgba(16, 11, 8, 0.26);
  border: 1px solid transparent;
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease, background 0.24s ease, color 0.24s ease;
}

body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link:hover,
body.site-shell .ftco-navbar-light .navbar-nav > .nav-item.active > a,
body.site-shell .ftco-navbar-light.scrolled .nav-link.active,
body.site-shell .navbar-nav .nav-link.active {
  transform: translateY(-1px);
  border-color: rgba(240, 217, 163, 0.14);
  background: linear-gradient(135deg, rgba(244, 222, 171, 0.18) 0%, rgba(201, 153, 68, 0.12) 100%);
  box-shadow:
    0 16px 32px rgba(20, 13, 9, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body.site-shell .home-slider .hero-subcta {
  margin: 16px 0 0;
  max-width: 42ch;
  font-size: 0.92rem;
  line-height: 1.6;
}

body.site-shell .home-slider .hero-subcta a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.88);
  border-bottom: 1px solid rgba(212, 175, 55, 0.34);
  padding-bottom: 3px;
}

body.site-shell .home-slider .hero-subcta a:hover,
body.site-shell .home-slider .hero-subcta a:focus {
  color: #f3d991;
  text-decoration: none;
  border-color: rgba(243, 217, 145, 0.56);
}

body.site-shell .home-logo-showcase {
  padding-top: 1rem;
  padding-bottom: 1.6rem;
}

body.site-shell .home-logo-showcase__panel {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(1.8rem, 4vw, 3rem);
  border-radius: 36px;
  background:
    radial-gradient(circle at top center, rgba(240, 217, 163, 0.26) 0%, rgba(240, 217, 163, 0.04) 26%, transparent 50%),
    linear-gradient(135deg, #241a13 0%, #110d0b 100%);
  border: 1px solid rgba(212, 175, 55, 0.18);
  box-shadow: 0 34px 78px rgba(18, 12, 8, 0.22);
}

body.site-shell .home-logo-showcase__panel::before,
body.site-shell .home-logo-showcase__panel::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

body.site-shell .home-logo-showcase__panel::before {
  width: 360px;
  height: 360px;
  top: -180px;
  left: -70px;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.3) 0%, rgba(212, 175, 55, 0) 72%);
}

body.site-shell .home-logo-showcase__panel::after {
  width: 300px;
  height: 300px;
  right: -90px;
  bottom: -140px;
  background: radial-gradient(circle, rgba(201, 153, 68, 0.28) 0%, rgba(201, 153, 68, 0) 74%);
}

body.site-shell .home-logo-showcase__frame {
  position: relative;
  z-index: 1;
  max-width: 840px;
  margin: 0 auto;
  padding: clamp(1.35rem, 3vw, 2.2rem);
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.97) 0%, rgba(250, 243, 231, 0.94) 100%);
  border: 1px solid rgba(255, 255, 255, 0.38);
  box-shadow:
    0 28px 60px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.84);
  backdrop-filter: blur(10px);
}

body.site-shell .home-logo-showcase__frame::before,
body.site-shell .home-logo-showcase__frame::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

body.site-shell .home-logo-showcase__frame::before {
  inset: 12px;
  border-radius: 24px;
  border: 1px solid rgba(212, 175, 55, 0.16);
}

body.site-shell .home-logo-showcase__frame::after {
  top: 50%;
  left: 50%;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(212, 175, 55, 0.2) 0%, rgba(212, 175, 55, 0) 72%);
}

body.site-shell .home-logo-showcase__image {
  position: relative;
  z-index: 1;
  display: block;
  width: min(100%, 620px);
  margin: 0 auto;
  filter:
    drop-shadow(0 32px 40px rgba(43, 29, 20, 0.2))
    drop-shadow(0 12px 22px rgba(212, 175, 55, 0.2));
  transition: transform 0.28s ease, filter 0.28s ease;
}

body.site-shell .home-logo-showcase__panel:hover .home-logo-showcase__image {
  transform: translateY(-4px) scale(1.015);
  filter:
    drop-shadow(0 36px 44px rgba(43, 29, 20, 0.24))
    drop-shadow(0 16px 26px rgba(212, 175, 55, 0.24));
}

body.site-shell .home-quick-access {
  padding-top: 2.1rem;
  padding-bottom: 4rem;
}

body.site-shell .home-quick-access__shell {
  position: relative;
  overflow: hidden;
  padding: clamp(1.4rem, 2.5vw, 2.15rem);
  border-radius: 32px;
  background:
    radial-gradient(circle at top left, rgba(255, 239, 208, 0.82) 0%, transparent 28%),
    radial-gradient(circle at bottom right, rgba(244, 214, 160, 0.45) 0%, transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 243, 233, 0.97) 100%);
  border: 1px solid rgba(201, 153, 68, 0.16);
  box-shadow: var(--surface-shadow-card);
}

body.site-shell .home-quick-access__shell::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.55);
  pointer-events: none;
}

body.site-shell .home-quick-access__intro {
  position: relative;
  z-index: 1;
  margin-bottom: 1.35rem;
  text-align: center;
}

body.site-shell .home-quick-access__eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.7rem;
  padding: 0.42rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(201, 153, 68, 0.18);
  color: #9b6a2a;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body.site-shell .home-quick-access__intro h2 {
  margin-bottom: 0.55rem;
  color: var(--dark-black);
  font-size: clamp(1.8rem, 3vw, 2.55rem);
  line-height: 1.08;
}

body.site-shell .home-quick-access__intro p {
  max-width: 48ch;
  margin: 0 auto;
  color: rgba(87, 68, 53, 0.82);
  font-size: 0.94rem;
  line-height: 1.65;
}

body.site-shell .home-quick-access__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

body.site-shell .home-quick-card {
  --quick-card-accent: #c99944;
  --quick-card-soft: rgba(201, 153, 68, 0.16);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 136px;
  padding: 1.15rem 0.95rem 1rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(252, 248, 242, 0.88) 100%);
  border: 1px solid rgba(201, 153, 68, 0.14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 18px 38px rgba(43, 29, 20, 0.08),
    0 6px 14px rgba(43, 29, 20, 0.04);
  color: var(--dark-black);
  text-align: center;
  text-decoration: none;
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

body.site-shell .home-quick-card:hover,
body.site-shell .home-quick-card:focus {
  transform: translateY(-6px);
  border-color: rgba(201, 153, 68, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    0 26px 48px rgba(43, 29, 20, 0.12),
    0 10px 20px rgba(43, 29, 20, 0.05);
  color: var(--dark-black);
  text-decoration: none;
}

body.site-shell .home-quick-card__icon {
  flex: 0 0 58px;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--quick-card-soft) 0%, rgba(255, 255, 255, 0.98) 100%);
  color: var(--quick-card-accent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.96),
    0 12px 24px rgba(43, 29, 20, 0.07);
  font-size: 1.28rem;
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

body.site-shell .home-quick-card:hover .home-quick-card__icon,
body.site-shell .home-quick-card:focus .home-quick-card__icon {
  transform: translateY(-2px) scale(1.04);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.98),
    0 16px 28px rgba(43, 29, 20, 0.1);
}

body.site-shell .home-quick-card__copy {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

body.site-shell .home-quick-card__copy strong {
  color: var(--dark-black);
  font-size: 0.98rem;
  font-weight: 700;
  line-height: 1.22;
}

body.site-shell .home-quick-card__copy small {
  color: rgba(95, 76, 61, 0.8);
  font-size: 0.75rem;
  line-height: 1.35;
}

body.site-shell .home-quick-card--youtube {
  --quick-card-accent: #e53935;
  --quick-card-soft: rgba(229, 57, 53, 0.16);
}

body.site-shell .home-quick-card--gallery {
  --quick-card-accent: #a65a2f;
  --quick-card-soft: rgba(166, 90, 47, 0.16);
}

body.site-shell .home-quick-card--reviews {
  --quick-card-accent: #4285f4;
  --quick-card-soft: rgba(66, 133, 244, 0.16);
}

body.site-shell .home-quick-card--justdial {
  --quick-card-accent: #f97316;
  --quick-card-soft: rgba(249, 115, 22, 0.16);
}

body.site-shell .home-quick-card--quote {
  --quick-card-accent: #2f855a;
  --quick-card-soft: rgba(47, 133, 90, 0.16);
}

body.site-shell .home-quick-card--whatsapp {
  --quick-card-accent: #25d366;
  --quick-card-soft: rgba(37, 211, 102, 0.16);
}

body.site-shell .home-quick-card--call {
  --quick-card-accent: #0f62ff;
  --quick-card-soft: rgba(15, 98, 255, 0.12);
}

body.site-shell .home-quick-card--maps {
  --quick-card-accent: #dc2626;
  --quick-card-soft: rgba(220, 38, 38, 0.16);
}

@media (max-width: 991.98px) {
  body.site-shell .navbar-nav > .nav-item {
    margin-left: 0;
  }

  body.site-shell .ftco-navbar-light .navbar-nav > .nav-item > .nav-link,
  body.site-shell .ftco-navbar-light.scrolled .nav-link,
  body.site-shell .navbar-nav .nav-link {
    font-family: 'Roboto', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 14px 16px !important;
    border-radius: 16px;
    text-shadow: none;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.05);
  }

  body.site-shell .home-quick-access__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  body.site-shell .home-logo-showcase {
    padding-top: 0.6rem;
    padding-bottom: 1rem;
  }

  body.site-shell .home-logo-showcase__panel {
    padding: 1.15rem;
    border-radius: 26px;
  }

  body.site-shell .home-logo-showcase__frame {
    padding: 1rem;
    border-radius: 22px;
  }

  body.site-shell .home-quick-access {
    padding-top: 1.4rem;
    padding-bottom: 3.2rem;
  }

  body.site-shell .home-quick-access__shell {
    padding: 1rem;
    border-radius: 24px;
  }

  body.site-shell .home-quick-access__intro {
    margin-bottom: 1.1rem;
  }

  body.site-shell .home-quick-access__intro h2 {
    font-size: 1.7rem;
  }

  body.site-shell .home-quick-access__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  body.site-shell .home-quick-card {
    min-height: 88px;
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    gap: 14px;
    padding: 0.95rem 1rem;
    border-radius: 18px;
  }

  body.site-shell .home-quick-card__icon {
    flex-basis: 40px;
    width: 40px;
    height: 40px;
    border-radius: 14px;
    font-size: 1rem;
  }

  body.site-shell .home-quick-card__copy strong {
    font-size: 0.95rem;
  }

  body.site-shell .home-quick-card__copy small {
    font-size: 0.76rem;
  }
}

body.design-studio-page {
  background:
    radial-gradient(circle at top left, rgba(244, 222, 171, 0.28), transparent 34%),
    linear-gradient(180deg, #fbf6ef 0%, #f3ebde 100%);
  color: #231912;
  padding-bottom: 108px;
}

body.design-studio-page.design-studio-panel-open {
  overflow: hidden;
}

body.design-studio-page [data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.56s ease, transform 0.56s ease;
}

body.design-studio-page [data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

.design-studio-hero {
  position: relative;
  padding: 9.2rem 0 5.8rem;
  overflow: hidden;
}

.design-studio-hero__glow {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(34, 23, 16, 0.9) 0%, rgba(60, 42, 28, 0.74) 44%, rgba(92, 67, 47, 0.3) 100%);
  pointer-events: none;
}

.design-studio-hero__layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 2rem;
  align-items: center;
}

.design-studio-hero__copy {
  color: #fffefb;
}

.design-studio-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.76);
}

.design-studio-hero__eyebrow::before {
  content: "";
  width: 52px;
  height: 1px;
  background: rgba(243, 217, 145, 0.72);
}

.design-studio-hero h1 {
  max-width: 11ch;
  margin: 0 0 18px;
  font-size: clamp(2.7rem, 6vw, 5rem);
  line-height: 0.98;
  color: #ffffff;
}

.design-studio-hero h1 span {
  color: #f1d286;
}

.design-studio-hero__lead {
  max-width: 34ch;
  margin: 0 0 28px;
  font-size: 1.08rem;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.86);
}

.design-studio-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 30px;
  padding: 0;
  list-style: none;
}

.design-studio-hero__chips li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.85rem;
  font-weight: 500;
}

.design-studio-hero__chips i {
  color: #f2cf76;
}

.design-studio-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.design-studio-hero__note {
  margin: 18px 0 0;
  max-width: 34ch;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.92rem;
}

.design-studio-hero__visual {
  position: relative;
  min-width: 0;
}

.design-studio-hero__frame {
  margin: 0;
  border-radius: 32px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow:
    0 26px 70px rgba(17, 11, 7, 0.36),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.design-studio-hero__frame img {
  display: block;
  width: 100%;
  height: min(560px, 66vh);
  object-fit: cover;
}

.design-studio-hero__proof {
  position: absolute;
  right: -12px;
  bottom: -28px;
  width: min(290px, 68%);
  display: block;
  padding: 12px;
  border-radius: 24px;
  background: rgba(255, 251, 246, 0.96);
  box-shadow: 0 24px 50px rgba(17, 11, 7, 0.24);
  text-decoration: none;
}

.design-studio-hero__proof:hover,
.design-studio-hero__proof:focus {
  transform: translateY(-4px);
  text-decoration: none;
}

.design-studio-hero__proof-label {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(196, 78, 53, 0.08);
  color: #a34b34;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.design-studio-hero__proof img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 14px;
}

.design-studio-shell {
  padding: 0 0 4rem;
}

.design-studio-sectionhead {
  max-width: 680px;
  margin: 0 auto 2.1rem;
  text-align: center;
}

.design-studio-sectionhead__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #aa7552;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.design-studio-sectionhead h2 {
  margin: 0 0 14px;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.08;
  color: #24160f;
}

.design-studio-sectionhead p {
  margin: 0;
  color: #685c50;
  font-size: 1rem;
  line-height: 1.75;
}

.design-studio-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.design-studio-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 1.35rem;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(249, 240, 229, 0.96) 100%);
  border: 1px solid rgba(166, 122, 72, 0.16);
  box-shadow:
    0 20px 48px rgba(43, 29, 20, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.78);
  cursor: pointer;
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.design-studio-card:hover,
.design-studio-card:focus-within {
  transform: translateY(-7px);
  box-shadow:
    0 26px 60px rgba(43, 29, 20, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.86);
  border-color: rgba(166, 122, 72, 0.26);
}

.design-studio-card__icon {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  border-radius: 18px;
  font-size: 1.28rem;
  background: rgba(212, 175, 55, 0.1);
  color: #b88a52;
}

.design-studio-card__body {
  flex: 1;
}

.design-studio-card__kicker {
  display: inline-block;
  margin-bottom: 9px;
  color: #9b7153;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.design-studio-card h3 {
  margin: 0 0 10px;
  font-size: 1.28rem;
  line-height: 1.18;
  color: #231710;
}

.design-studio-card p {
  margin: 0 0 1.2rem;
  color: #695d51;
  line-height: 1.7;
}

.design-studio-card__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  min-height: 48px;
  padding: 0.85rem 1.2rem;
  border: 0;
  border-radius: 999px;
  background: #231912;
  color: #fffaf5;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  box-shadow: 0 16px 28px rgba(35, 25, 18, 0.14);
  transition: transform 0.24s ease, box-shadow 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.design-studio-card__button:hover,
.design-studio-card__button:focus {
  color: #fffaf5;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 18px 32px rgba(35, 25, 18, 0.2);
}

button.design-studio-card__button {
  cursor: pointer;
}

.design-studio-card--video .design-studio-card__icon {
  background: rgba(214, 73, 60, 0.1);
  color: #d6493c;
}

.design-studio-card--gallery .design-studio-card__icon {
  background: rgba(184, 138, 82, 0.12);
  color: #9f6a39;
}

.design-studio-card--reviews .design-studio-card__icon {
  background: rgba(70, 113, 211, 0.1);
  color: #4971d1;
}

.design-studio-card--planner .design-studio-card__icon {
  background: rgba(59, 116, 94, 0.1);
  color: #3b745e;
}

.design-studio-card--quote .design-studio-card__icon {
  background: rgba(37, 211, 102, 0.1);
  color: #22a95b;
}

.design-studio-card--call .design-studio-card__icon {
  background: rgba(170, 117, 82, 0.14);
  color: #945631;
}

.design-studio-card--later .design-studio-card__icon {
  background: rgba(123, 90, 163, 0.1);
  color: #7b5aa3;
}

.design-studio-steps {
  padding: 0 0 4.6rem;
}

.design-studio-steps__shell {
  padding: 2rem;
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(37, 26, 19, 0.96) 0%, rgba(65, 45, 31, 0.95) 100%);
  box-shadow: 0 28px 70px rgba(33, 23, 17, 0.16);
}

.design-studio-steps__intro h2 {
  margin: 0;
  color: #fffaf3;
  font-size: clamp(1.8rem, 4vw, 2.7rem);
}

.design-studio-steps__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 1.5rem;
}

.design-studio-step {
  padding: 1.25rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.design-studio-step span {
  display: inline-block;
  margin-bottom: 10px;
  color: #f1d286;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

.design-studio-step h3 {
  margin: 0 0 8px;
  color: #fffef8;
  font-size: 1.1rem;
}

.design-studio-step p {
  margin: 0;
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.7;
}

.design-studio-overlay {
  position: fixed;
  inset: 0;
  z-index: 9990;
  background: rgba(20, 13, 9, 0.64);
  opacity: 0;
  transition: opacity 0.22s ease;
}

.design-studio-overlay.is-visible {
  opacity: 1;
}

.design-studio-panel {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
}

.design-studio-panel.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.design-studio-panel__dialog {
  position: relative;
  width: min(720px, 100%);
  max-height: min(88vh, 880px);
  overflow-y: auto;
  padding: 2rem;
  border-radius: 30px;
  background: linear-gradient(180deg, #fffdf9 0%, #f7eee3 100%);
  box-shadow:
    0 34px 80px rgba(20, 13, 9, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
  transform: translateY(16px);
  transition: transform 0.22s ease;
}

.design-studio-panel.is-visible .design-studio-panel__dialog {
  transform: translateY(0);
}

.design-studio-panel__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: rgba(35, 25, 18, 0.08);
  color: #231912;
  cursor: pointer;
}

.design-studio-panel__eyebrow,
.design-studio-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.design-studio-panel__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #aa7552;
}

.design-studio-panel h2 {
  margin: 0 0 10px;
  color: #24160f;
  font-size: clamp(1.9rem, 4vw, 2.7rem);
}

.design-studio-panel__lead {
  margin: 0 0 1.5rem;
  color: #685c50;
  line-height: 1.75;
}

.design-studio-form .form-control {
  min-height: 52px;
  border-radius: 16px;
  border: 1px solid rgba(166, 122, 72, 0.2);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: none;
}

.design-studio-form textarea.form-control {
  min-height: 120px;
}

.design-studio-form .form-control:focus {
  border-color: rgba(196, 78, 53, 0.4);
  box-shadow: 0 0 0 4px rgba(196, 78, 53, 0.08);
}

.design-studio-label {
  display: block;
  margin-bottom: 0.55rem;
  color: #8e654a;
}

.design-studio-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 1rem;
}

.design-studio-panel__saved {
  padding: 0.95rem 1rem;
  border-radius: 16px;
  background: rgba(59, 116, 94, 0.08);
  color: #335e4d;
  font-size: 0.95rem;
}

.design-studio-sticky {
  display: none;
}

@media (max-width: 1199.98px) {
  .design-studio-hero__layout {
    grid-template-columns: 1fr;
  }

  .design-studio-hero__copy {
    max-width: 680px;
  }

  .design-studio-hero__frame img {
    height: min(520px, 58vh);
  }
}

@media (max-width: 991.98px) {
  .design-studio-hero {
    padding-top: 8.2rem;
  }

  .design-studio-grid,
  .design-studio-steps__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .design-studio-hero__proof {
    position: static;
    width: min(360px, 100%);
    margin-top: 1rem;
  }

  .design-studio-sticky {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 10020;
    display: block;
  }

  .design-studio-sticky .btn {
    width: 100%;
    min-height: 56px;
  }
}

@media (max-width: 767.98px) {
  body.design-studio-page {
    padding-bottom: 96px;
  }

  .design-studio-hero {
    padding: 7.6rem 0 4.4rem;
  }

  .design-studio-hero__eyebrow::before {
    width: 36px;
  }

  .design-studio-hero__lead,
  .design-studio-hero__note {
    max-width: none;
  }

  .design-studio-hero__actions,
  .design-studio-form__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .design-studio-hero__actions .btn,
  .design-studio-form__actions .btn {
    width: 100%;
  }

  .design-studio-steps__shell,
  .design-studio-panel__dialog {
    padding: 1.35rem;
    border-radius: 24px;
  }

  .design-studio-panel {
    padding: 14px;
  }
}

@media (max-width: 575.98px) {
  .design-studio-grid,
  .design-studio-steps__grid {
    grid-template-columns: 1fr;
  }

  .design-studio-card,
  .design-studio-step {
    border-radius: 24px;
  }

  .design-studio-sectionhead {
    text-align: left;
  }

  .design-studio-hero__chips li {
    width: 100%;
    justify-content: flex-start;
  }

  body.site-shell .home-slider .hero-subcta {
    max-width: none;
    font-size: 0.88rem;
  }
}

/* ============================================
   HOME HERO LUXURY REFRESH
   ============================================ */

body.site-shell .home-slider .slider-item.hero-slide {
  overflow: hidden;
  background-color: #fbf3e7;
  background-position: center center !important;
}

body.site-shell .home-slider .slider-item.hero-slide.hero-slide--video {
  background-image: url("../images/background-projects.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}

body.site-shell .home-slider .hero-background-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  pointer-events: none;
  z-index: 0;
}

body.site-shell .home-slider .slider-item.hero-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 76% 22%, rgba(255, 245, 224, 0.3) 0%, rgba(255, 245, 224, 0.12) 18%, rgba(255, 245, 224, 0) 42%),
    radial-gradient(circle at 86% 82%, rgba(240, 200, 132, 0.12) 0%, rgba(240, 200, 132, 0) 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0));
  pointer-events: none;
}

body.site-shell .home-slider .slider-item.hero-slide::after {
  content: "";
  position: absolute;
  left: -6%;
  bottom: 4%;
  width: min(32vw, 360px);
  height: min(32vw, 360px);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 250, 239, 0.54) 0%, rgba(244, 222, 171, 0.12) 34%, rgba(244, 222, 171, 0) 72%);
  filter: blur(6px);
  pointer-events: none;
}

body.site-shell .home-slider .slider-item.hero-slide::before,
body.site-shell .home-slider .slider-item.hero-slide::after {
  z-index: 1;
}

body.site-shell .home-slider .slider-item.hero-slide .overlay {
  display: block;
  background: linear-gradient(96deg, rgba(16, 12, 9, 0.66) 0%, rgba(20, 15, 12, 0.54) 28%, rgba(31, 23, 17, 0.28) 58%, rgba(31, 23, 17, 0.06) 82%, rgba(31, 23, 17, 0) 100%);
  opacity: 1;
  z-index: 2;
}

body.site-shell .home-slider .slider-item.hero-slide .container,
body.site-shell .home-slider .slider-item.hero-slide .slider-text {
  position: relative;
  z-index: 3;
}

body.site-shell .home-slider .hero-text {
  position: relative;
  max-width: 650px;
  padding: 0 34px 0 0;
  border-radius: 0;
  background: none;
  border: 0;
  box-shadow: none;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

body.site-shell .home-slider .hero-text::before {
  content: "";
  position: absolute;
  left: 0;
  top: -22px;
  width: 84px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(214, 182, 122, 0.98) 0%, rgba(244, 222, 171, 0.36) 100%);
  pointer-events: none;
}

body.site-shell .home-slider .hero-text::after {
  content: "";
  position: absolute;
  top: -48px;
  left: -26px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.44) 0%, rgba(243, 217, 145, 0.12) 34%, rgba(243, 217, 145, 0) 72%);
  pointer-events: none;
}

body.site-shell .home-slider .hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  width: fit-content;
  margin-bottom: 1rem;
  padding: 0.62rem 0.95rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.16) 0%, rgba(244, 222, 171, 0.14) 100%);
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 12px 24px rgba(16, 11, 8, 0.14);
  color: #fff7e8;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body.site-shell .home-slider .hero-kicker::before {
  content: none;
}

body.site-shell .home-slider .hero-kicker i {
  color: #f3d991;
  font-size: 0.86rem;
}

body.site-shell .home-slider .hero-text h1 {
  max-width: 11ch;
  margin-bottom: 1rem;
  font-size: clamp(2.6rem, 5.3vw, 5rem);
  line-height: 0.98;
  letter-spacing: -0.02em;
  color: #fffaf1;
  text-shadow: 0 16px 34px rgba(9, 6, 5, 0.34);
}

body.site-shell .home-slider .hero-text h1 span {
  color: #f3d991;
}

body.site-shell .home-slider .hero-lead {
  max-width: 32ch;
  margin: 0;
  font-size: clamp(0.98rem, 1.2vw, 1.12rem);
  line-height: 1.7;
  color: rgba(255, 247, 234, 0.92);
  text-shadow: 0 12px 24px rgba(9, 6, 5, 0.22);
}

body.site-shell .home-slider .hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
}

body.site-shell .home-slider .hero-proof li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0.78rem 1rem;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.16) 0%, rgba(244, 222, 171, 0.12) 100%);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 14px 28px rgba(16, 11, 8, 0.16);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff9ef;
  font-size: 0.88rem;
  font-weight: 600;
}

body.site-shell .home-slider .hero-proof li i {
  color: #f3d991;
  font-size: 0.92rem;
}

@media (max-width: 991.98px) {
  body.site-shell .home-slider .slider-item.hero-slide {
    background-position: 60% center !important;
  }

  body.site-shell .home-slider .hero-text {
    max-width: 560px;
  }
}

@media (max-width: 767.98px) {
  body.site-shell .home-slider .slider-item.hero-slide {
    background-position: 64% center !important;
  }

  body.site-shell .home-slider .slider-item.hero-slide .slider-text {
    text-align: left;
  }

  body.site-shell .home-slider .hero-text {
    max-width: none;
    padding: 0 0.5rem 0 0;
  }

  body.site-shell .home-slider .hero-text::after {
    width: 120px;
    height: 120px;
    top: -34px;
    left: -12px;
  }

  body.site-shell .home-slider .hero-text::before {
    top: -16px;
    width: 60px;
  }

  body.site-shell .home-slider .hero-text h1 {
    max-width: 11ch;
    font-size: clamp(2rem, 9vw, 3rem);
  }

  body.site-shell .home-slider .hero-lead {
    max-width: 28ch;
    font-size: 0.95rem;
    line-height: 1.65;
  }

  body.site-shell .home-slider .hero-proof {
    gap: 10px;
    margin-top: 1.15rem;
  }

  body.site-shell .home-slider .hero-proof li {
    padding: 0.72rem 0.9rem;
    font-size: 0.8rem;
  }
}

@media (max-width: 575.98px) {
  body.site-shell .home-slider .slider-item.hero-slide .overlay {
    background: linear-gradient(180deg, rgba(16, 12, 9, 0.38) 0%, rgba(20, 15, 12, 0.56) 44%, rgba(31, 23, 17, 0.28) 100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.site-shell .home-slider .hero-background-video {
    display: none;
  }
}

/* ============================================
   LUXURY MOTION SYSTEM
   ============================================ */

html.motion-enabled .ftco-animate {
  visibility: hidden;
  opacity: 0;
  transform: translate3d(0, 36px, 0) scale(0.985);
  filter: blur(1px);
  transition:
    opacity 0.82s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--motion-delay, 0ms);
  will-change: opacity, transform;
}

html.motion-enabled .ftco-animate[data-motion="left"] {
  transform: translate3d(-42px, 24px, 0) scale(0.985);
}

html.motion-enabled .ftco-animate[data-motion="right"] {
  transform: translate3d(42px, 24px, 0) scale(0.985);
}

html.motion-enabled .ftco-animate[data-motion="zoom"] {
  transform: translate3d(0, 20px, 0) scale(0.94);
}

html.motion-enabled .ftco-animate[data-motion="soft"] {
  transform: translate3d(0, 18px, 0) scale(0.995);
}

html.motion-enabled .ftco-animate.ftco-animated {
  visibility: visible;
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

html.motion-enabled .home-slider .hero-text.ftco-animate {
  transition-duration: 1s, 1.04s, 1.04s;
}

html.motion-enabled .home-quick-card.ftco-animate,
html.motion-enabled .youtube-wall-card.ftco-animate,
html.motion-enabled .services-page__service-panel.ftco-animate,
html.motion-enabled .story-card.ftco-animate,
html.motion-enabled .staff.ftco-animate {
  transition-duration: 0.78s, 0.84s, 0.84s;
}

@media (max-width: 767.98px) {
  html.motion-enabled .ftco-animate,
  html.motion-enabled .ftco-animate[data-motion="left"],
  html.motion-enabled .ftco-animate[data-motion="right"] {
    transform: translate3d(0, 26px, 0) scale(0.99);
  }

  html.motion-enabled .ftco-animate[data-motion="zoom"] {
    transform: translate3d(0, 18px, 0) scale(0.965);
  }
}

@media (prefers-reduced-motion: reduce) {
  html.motion-enabled .ftco-animate {
    visibility: visible;
    opacity: 1;
    transform: none !important;
    filter: none;
    transition: none;
  }
}

/* ============================================
   FINAL 3D LUXE POLISH
   ============================================ */

body.site-shell .home-slider .hero-actions,
body.site-shell .home-quick-access__shell,
body.site-shell .youtube-wall-shell,
body.site-shell .home-logo-showcase__panel,
body.site-shell .home-logo-showcase__frame,
body.site-shell .home-quick-card,
body.site-shell .youtube-wall-card,
.services-page__service-panel,
.project-note,
.story-card .text,
body.site-shell .contact-option,
body.site-shell .translate-cta__toggle {
  transform-style: preserve-3d;
  will-change: transform, box-shadow;
}

body.site-shell .home-slider .hero-actions {
  perspective: 1400px;
  box-shadow:
    0 24px 56px rgba(10, 8, 7, 0.26),
    0 10px 24px rgba(10, 8, 7, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

body.site-shell .home-slider .hero-icon-link,
body.site-shell .home-slider .hero-proof li,
body.site-shell .home-slider .hero-kicker,
body.site-shell .home-slider .hero-text h1,
body.site-shell .home-slider .hero-lead,
body.site-shell .home-quick-card__icon,
body.site-shell .home-quick-card__copy,
body.site-shell .youtube-wall-card__badge,
body.site-shell .youtube-wall-card__title,
.services-page__panel-copy,
.project-note > *,
.story-card .text > * {
  position: relative;
  z-index: 1;
  transform: translateZ(16px);
}

body.site-shell .home-slider .hero-text h1 {
  transform: translateZ(26px);
}

body.site-shell .home-slider .hero-lead,
body.site-shell .home-slider .hero-kicker {
  transform: translateZ(20px);
}

body.site-shell .home-quick-card,
body.site-shell .youtube-wall-card,
.services-page__service-panel,
.project-note,
.story-card .text,
body.site-shell .contact-option,
body.site-shell .translate-cta__toggle {
  position: relative;
  overflow: hidden;
}

body.site-shell .home-quick-card::before,
body.site-shell .youtube-wall-card::before,
.services-page__service-panel::before,
.project-note::before,
.story-card .text::before,
body.site-shell .contact-option::before,
body.site-shell .translate-cta__toggle::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.28) 0%, rgba(255, 255, 255, 0.08) 24%, transparent 48%),
    linear-gradient(140deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.04) 22%, transparent 48%, transparent 68%, rgba(240, 217, 163, 0.12) 100%);
  opacity: 0.95;
  pointer-events: none;
}

body.site-shell .home-quick-card::after,
body.site-shell .youtube-wall-card::after,
.services-page__service-panel::after,
.project-note::after,
.story-card .text::after,
body.site-shell .contact-option::after,
body.site-shell .translate-cta__toggle::after {
  content: "";
  position: absolute;
  top: -34%;
  left: -24%;
  width: 48%;
  height: 170%;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0));
  transform: rotate(18deg) translateX(-155%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.5s ease;
  mix-blend-mode: screen;
}

body.site-shell .home-logo-showcase__panel {
  perspective: 1600px;
  box-shadow:
    0 38px 90px rgba(18, 12, 8, 0.22),
    0 14px 28px rgba(18, 12, 8, 0.08);
}

body.site-shell .home-logo-showcase__frame {
  box-shadow:
    0 30px 68px rgba(0, 0, 0, 0.2),
    0 14px 28px rgba(43, 29, 20, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

body.site-shell .home-logo-showcase__image {
  transform: translateZ(24px);
}

body.site-shell .home-page .gallery-card__content,
body.site-shell .home-page .gallery-zoom {
  position: relative;
  z-index: 1;
  transition: transform 0.32s ease, box-shadow 0.32s ease;
}

body.site-shell .home-page .gallery-card__content {
  transform: translateZ(18px);
}

body.site-shell .home-page .gallery-zoom {
  transform: translateZ(30px);
}

body.site-shell .youtube-wall-card__media {
  transform: translateZ(12px);
}

body.site-shell .contact-option,
body.site-shell .translate-cta__toggle {
  box-shadow:
    0 18px 36px rgba(43, 29, 20, 0.12),
    0 8px 18px rgba(43, 29, 20, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

@media (hover: hover) and (pointer: fine) {
  body.site-shell .home-slider .hero-actions:hover {
    transform: perspective(1400px) rotateX(5deg) translateY(-4px);
  }

  body.site-shell .home-slider .hero-icon-link:hover,
  body.site-shell .home-slider .hero-icon-link:focus {
    transform: translateY(-4px) translateZ(24px) scale(1.04);
  }

  body.site-shell .home-quick-card:hover,
  body.site-shell .home-quick-card:focus {
    transform: perspective(1400px) rotateX(7deg) rotateY(-6deg) translateY(-10px);
  }

  body.site-shell .home-quick-card:nth-child(even):hover,
  body.site-shell .home-quick-card:nth-child(even):focus {
    transform: perspective(1400px) rotateX(7deg) rotateY(6deg) translateY(-10px);
  }

  body.site-shell .youtube-wall-card:hover,
  body.site-shell .youtube-wall-card:focus {
    transform: perspective(1500px) rotateX(6deg) rotateY(-5deg) translateY(-10px);
  }

  body.site-shell .youtube-wall-card:nth-child(even):hover,
  body.site-shell .youtube-wall-card:nth-child(even):focus {
    transform: perspective(1500px) rotateX(6deg) rotateY(5deg) translateY(-10px);
  }

  .services-page__service-panel:hover {
    transform: perspective(1600px) rotateX(5deg) rotateY(-3deg) translateY(-10px);
  }

  .services-page__service-panel:nth-child(even):hover {
    transform: perspective(1600px) rotateX(5deg) rotateY(3deg) translateY(-10px);
  }

  .project-note:hover,
  .story-card:hover .text {
    transform: perspective(1400px) rotateX(5deg) translateY(-8px);
  }

  body.site-shell .contact-option:hover,
  body.site-shell .contact-option:focus,
  body.site-shell .translate-cta__toggle:hover,
  body.site-shell .translate-cta__toggle:focus {
    transform: perspective(1200px) rotateX(7deg) translateY(-6px) scale(1.03);
  }

  body.site-shell .home-logo-showcase__panel:hover {
    transform: perspective(1800px) rotateX(4deg) rotateY(-3deg) translateY(-10px);
  }

  body.site-shell .home-logo-showcase__panel:hover .home-logo-showcase__frame {
    transform: translateZ(22px);
  }

  body.site-shell .home-page .gallery-card:hover,
  body.site-shell .home-page .gallery-card:focus {
    transform: perspective(1600px) rotateX(5deg) rotateY(-4deg) translateY(-10px);
  }

  body.site-shell .home-page .gallery-card:nth-child(even):hover,
  body.site-shell .home-page .gallery-card:nth-child(even):focus {
    transform: perspective(1600px) rotateX(5deg) rotateY(4deg) translateY(-10px);
  }

  body.site-shell .home-page .gallery-card:hover .gallery-card__content,
  body.site-shell .home-page .gallery-card:focus .gallery-card__content {
    transform: translateZ(30px) translateY(-2px);
  }

  body.site-shell .home-page .gallery-card:hover .gallery-zoom,
  body.site-shell .home-page .gallery-card:focus .gallery-zoom {
    transform: translateZ(44px) translateY(-3px) scale(1.08);
  }

  body.site-shell .home-quick-card:hover::after,
  body.site-shell .home-quick-card:focus::after,
  body.site-shell .youtube-wall-card:hover::after,
  body.site-shell .youtube-wall-card:focus::after,
  .services-page__service-panel:hover::after,
  .project-note:hover::after,
  .story-card:hover .text::after,
  body.site-shell .contact-option:hover::after,
  body.site-shell .contact-option:focus::after,
  body.site-shell .translate-cta__toggle:hover::after,
  body.site-shell .translate-cta__toggle:focus::after {
    opacity: 1;
    transform: rotate(18deg) translateX(300%);
  }
}

@media (max-width: 991.98px) {
  body.site-shell .home-slider .hero-actions,
  body.site-shell .home-logo-showcase__panel,
  body.site-shell .home-quick-card,
  body.site-shell .youtube-wall-card,
  .services-page__service-panel,
  .project-note,
  .story-card .text {
    transform-style: flat;
  }

  body.site-shell .home-page .gallery-card__content,
  body.site-shell .home-page .gallery-zoom,
  body.site-shell .home-quick-card__icon,
  body.site-shell .home-quick-card__copy,
  body.site-shell .youtube-wall-card__badge,
  body.site-shell .youtube-wall-card__title,
  .services-page__panel-copy,
  .project-note > *,
  .story-card .text > * {
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.site-shell .site-brand__logo,
  body.site-shell .home-slider .hero-actions,
  body.site-shell .home-logo-showcase__panel,
  body.site-shell .home-quick-card,
  body.site-shell .youtube-wall-card,
  .services-page__service-panel,
  .project-note,
  .story-card .text,
  body.site-shell .contact-option,
  body.site-shell .translate-cta__toggle,
  body.site-shell .home-page .gallery-card,
  body.site-shell .home-page .gallery-card__content,
  body.site-shell .home-page .gallery-zoom {
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }

  body.site-shell .home-quick-card::after,
  body.site-shell .youtube-wall-card::after,
  .services-page__service-panel::after,
  .project-note::after,
  .story-card .text::after,
  body.site-shell .contact-option::after,
  body.site-shell .translate-cta__toggle::after {
    display: none;
  }
}
