@charset "UTF-8";
/*!
* Start Bootstrap - Agency v6.0.2 (https://startbootstrap.com/template-overviews/agency)
* Copyright 2013-2020 Start Bootstrap
* Licensed under MIT (https://github.com/StartBootstrap/startbootstrap-agency/blob/master/LICENSE)
*/
/*!
 * Bootstrap v4.5.0 (https://getbootstrap.com/)
 * Copyright 2011-2020 The Bootstrap Authors
 * Copyright 2011-2020 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: #fed136;
  --green: #28a745;
  --teal: #20c997;
  --cyan: #17a2b8;
  --white: #fff;
  --gray: #6c757d;
  --gray-dark: #343a40;
  --primary: #fed136;
  --secondary: #6c757d;
  --success: #28a745;
  --info: #17a2b8;
  --warning: #fed136;
  --danger: #dc3545;
  --light: #f8f9fa;
  --dark: #343a40;
  --breakpoint-xs: 0;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --font-family-serif: "Hoefler Text Engraved", serif;
  --font-family-sans-serif:
    "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji",
    "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --font-family-monospace:
    SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New",
    monospace;

  --galaxy-bg: url("//galaxy.tealab.com/public/img/themes/default/login-bg.jpg");

  --masthead-height: min(100vh, 900px);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

footer,
header,
main,
section {
  display: block;
}

body {
  margin: 0;
  font-family:
    "Roboto Slab",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    sans-serif,
    "Apple Color Emoji",
    "Segoe UI Emoji",
    "Segoe UI Symbol",
    "Noto Color Emoji";
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  text-align: left;
  background-color: #000;
}

[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important;
}

a {
  color: #fed136;
  text-decoration: none;
  background-color: transparent;
}
a:hover {
  color: #e6b301;
  text-decoration: none;
}

a:not([href]) {
  color: inherit;
  text-decoration: none;
}
a:not([href]):hover {
  color: inherit;
  text-decoration: none;
}

img {
  vertical-align: middle;
  border-style: none;
}

button {
  border-radius: 0;
}

button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color;
}

button {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button {
  overflow: visible;
}

button {
  text-transform: none;
}

[role="button"] {
  cursor: pointer;
}

button,
[type="button"] {
  -webkit-appearance: button;
}

button:not(:disabled),
[type="button"]:not(:disabled) {
  cursor: pointer;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

template {
  display: none;
}

[hidden] {
  display: none !important;
}

.img-fluid {
  max-width: 100%;
  height: auto;
}

.container {
  width: 100%;
  padding-right: 0.75rem;
  padding-left: 0.75rem;
  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;
  }
}

@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;
  }
}
.row {
  display: flex;
  flex-wrap: wrap;
  margin-right: -0.75rem;
  margin-left: -0.75rem;
}

.col-lg-12,
.col-lg-4,
.col-sm-6 {
  position: relative;
  width: 100%;
  padding-right: 0.75rem;
  padding-left: 0.75rem;
}

@media (min-width: 576px) {
  .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media (min-width: 992px) {
  .col-lg-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }

  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}

.fade {
  transition: opacity 0.15s linear;
}
@media (prefers-reduced-motion: reduce) {
  .fade {
    transition: none;
  }
}
.fade:not(.show) {
  opacity: 0;
}

.collapsing {
  position: relative;
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .collapsing {
    transition: none;
  }
}

.alert {
  position: relative;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: 0.25rem;
}

.media {
  display: flex;
  align-items: flex-start;
}

.close {
  float: right;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  color: #000;
  text-shadow: 0 1px 0 #fff;
  opacity: 0.5;
}
.close:hover {
  color: #000;
  text-decoration: none;
}
.close:not(:disabled):not(.disabled):hover,
.close:not(:disabled):not(.disabled):focus {
  opacity: 0.75;
}

button.close {
  padding: 0;
  background-color: transparent;
  border: 0;
}

a.close.disabled {
  pointer-events: none;
}

.modal-open {
  overflow: hidden;
}
.modal-open .modal {
  overflow-x: hidden;
  overflow-y: auto;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  display: none;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  outline: 0;
}

.modal-dialog {
  position: relative;
  width: auto;
  margin: 0.5rem;
  pointer-events: none;
}
.modal.fade .modal-dialog {
  transition: transform 0.3s ease-out;
  transform: translate(0, -50px);
}
@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    transition: none;
  }
}
.modal.show .modal-dialog {
  transform: none;
}
.modal.modal-static .modal-dialog {
  transform: scale(1.02);
}

/* .modal-dialog-scrollable {
  display: flex;
  max-height: calc(100% - 1rem);
}
.modal-dialog-scrollable .modal-content {
  max-height: calc(100vh - 1rem);
  overflow: hidden;
}
.modal-dialog-scrollable .modal-header,
.modal-dialog-scrollable .modal-footer {
  flex-shrink: 0;
}
.modal-dialog-scrollable .modal-body {
  overflow-y: auto;
} */

/* Modal IFrame */
.viewer {
  border: none;
  min-width: 520px;
  height: 100%;
  min-height: 955px;
  margin: auto;
  display: block;
  transform-origin: center left;
  z-index: 8;

  /* Portrait Video Viewer - desktop */
  &.video-in-phone {
    min-height: 750px;
    margin-top: 2rem;
  }

  /* Carousel - desktop */
  &.fb-2018-carousel {
    min-height: 795px;
  }
}

@media (max-width: 600px) {
  /* Portrait Video Viewer - mobile */
  .viewer.video-in-phone {
    min-height: 870px;
    margin-top: 0;
    margin-bottom: -33vh;
  }
}

@media (max-width: 600px) {
  /* Carousel - mobile */
  .viewer.fb-2018-carousel {
    min-height: 900px;
  }
}

@media (max-width: 600px) {
  /* Standard templates */
  .viewer {
    min-height: 900px;
    /* margin-top: -3rem; */
    /* margin-bottom: -16vh; */
    transform-origin: top left;
  }
}

.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - 1rem);
}
.modal-dialog-centered::before {
  display: block;
  height: calc(100vh - 1rem);
  height: -webkit-min-content;
  height: -moz-min-content;
  height: min-content;
  content: "";
}
.modal-dialog-centered.modal-dialog-scrollable {
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.modal-dialog-centered.modal-dialog-scrollable .modal-content {
  max-height: none;
}
.modal-dialog-centered.modal-dialog-scrollable::before {
  content: none;
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #000;
}
.modal-backdrop.fade {
  opacity: 0;
}
.modal-backdrop.show {
  opacity: 0.5;
}

/* .modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 1rem 1rem;
  border-bottom: 1px solid #dee2e6;
  border-top-left-radius: calc(0.3rem - 1px);
  border-top-right-radius: calc(0.3rem - 1px);
  & .close {
    padding: 1rem 1rem;
    margin: -1rem -1rem -1rem auto;
  }

  & .modal-title {
    margin-bottom: 0;
    line-height: 1.5;
  }
} */
@media (max-width: 600px) {
  .col-lg-12.modal-body-wrapper {
    padding: 0;
  }
}
.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: 1rem;
}

.modal-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  padding: 0.75rem;
  border-top: 1px solid #dee2e6;
  border-bottom-right-radius: calc(0.3rem - 1px);
  border-bottom-left-radius: calc(0.3rem - 1px);
  & > * {
    margin: 0.25rem;
  }
}

.modal-scrollbar-measure {
  position: absolute;
  top: -9999px;
  width: 50px;
  height: 50px;
  overflow: scroll;
}

@media (min-width: 576px) {
  .modal-dialog {
    max-width: 500px;
    margin: 1.75rem auto;
  }

  .modal-dialog-scrollable {
    max-height: calc(100% - 3.5rem);
  }
  .modal-dialog-scrollable .modal-content {
    max-height: calc(100vh - 3.5rem);
  }

  .modal-dialog-centered {
    min-height: calc(100% - 3.5rem);
  }
  .modal-dialog-centered::before {
    height: calc(100vh - 3.5rem);
    height: -webkit-min-content;
    height: -moz-min-content;
    height: min-content;
  }

  .modal-sm {
    max-width: 300px;
  }
}
@media (min-width: 992px) {
  .modal-lg,
  .modal-xl {
    max-width: 800px;
  }
}
@media (min-width: 1200px) {
  .modal-xl {
    max-width: 1140px;
  }
}

.carousel {
  position: relative;
}

.bg-light {
  background-color: #f8f9fa !important;
}

@media print {
  *,
  *::before,
  *::after {
    text-shadow: none !important;
    box-shadow: none !important;
  }

  a:not(.btn) {
    text-decoration: underline;
  }

  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;
  }
}
body {
  overflow-x: hidden;
}

p {
  line-height: 1.75;
}

.page-section {
  margin-top: 100vh;
  margin-top: var(--masthead-height);
  padding: 5rem 0;
  background: red;
  transform: translateZ(-1px);
}

@media (min-width: 768px) {
  section {
    padding: 9rem 0;
  }
}
::-moz-selection {
  background: #fed136;
  text-shadow: none;
}

::selection {
  background: var(--gray);
  text-shadow: none;
}

img::-moz-selection {
  background: transparent;
}

img::selection {
  background: transparent;
}

img::-moz-selection {
  background: transparent;
}

.btn-xl {
  padding: 1.25rem 2.5rem;
  font-family: var(--font-family-sans-serif);
  font-size: 1.125rem;
  font-weight: 700;
}

.btn-social {
  height: 2.5rem;
  width: 2.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 100%;
}

header.masthead {
  display: flex;

  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
  height: var(--masthead-height);

  flex-direction: column;
  justify-content: center;
  align-items: center;

  background-color: #fff;
  background-repeat: no-repeat;
  background-attachment: scroll;
  background-position: center center;
  background-size: cover;

  z-index: 0;
  transform: translateZ(-1px);
}

.ready header.masthead {
  /* transition: none; */
}

.masthead-subheading {
}

.logo-2022 {
  max-width: 100%;
}

@keyframes fade-in {
  0% {
    opacity: 0;
    transform: translateY(-1rem);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* The big grid */
.portfolio-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 0;

  /* First level of individual item */
  & .portfolio-item-wrapper {
    display: flex;
    flex-direction: column;

    /* Clickable <a> */
    & .portfolio-link {
      position: relative;
      display: flex;
      height: auto;
      flex-shrink: 0;
      flex-grow: 1;
      margin: 0 auto;
      overflow: hidden;
      cursor: pointer;

      & .portfolio-item {
        max-width: 25rem;
        margin-left: auto;
        margin-right: auto;
        overflow: hidden;
        display: flex;
        flex-direction: column;

        & .portfolio-thumbnail-wrapper {
          width: 100%;
          height: auto;
          overflow: hidden;
          position: relative;

          /* Thumbnail image */
          & .portfolio-thumbnail {
            background: var(--galaxy-bg);
            background-repeat: no-repeat;
            background-position: center;
            background-size: cover;
            transition: all 0.3s;
            z-index: 0;
            width: 100%;
          }

          & .portfolio-hover {
            position: absolute;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.49);
            opacity: 0;
            transition: opacity ease-in-out 0.25s;
            z-index: 2;
          }

          & .portfolio-hover-content {
            outline: 1px solid #ccc;
            transition: all 0.25s;
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            left: 0;
          }
        }

        /* Title + Subtitle below thumbnail image */
        .portfolio-caption {
          padding: 1.5rem;
          text-align: center;
          background-color: #fff;
          flex-grow: 1;
          /* Title in bold font */
          & .portfolio-caption-heading {
            font-size: 1.5rem;
            font-family: var(--font-family-sans-serif);
            font-weight: 700;
            margin-bottom: 0;
            color: #111;
          }
          /* Subtitle in italic */
          & .portfolio-caption-subheading {
            color: rgb(108, 117, 125);
            font-style: italic;
            font-family:
              "Droid Serif",
              -apple-system,
              BlinkMacSystemFont,
              "Segoe UI",
              Roboto,
              "Helvetica Neue",
              Arial,
              sans-serif,
              "Apple Color Emoji",
              "Segoe UI Emoji",
              "Segoe UI Symbol",
              "Noto Color Emoji";
          }
        }
      }
    }
  }
}

@media (min-width: 600px) {
  .portfolio-link:hover .portfolio-thumbnail {
    transform: scale(1.1);
    filter: saturate(1.3);
  }
}

/* #portfolio .portfolio-item .portfolio-link { */

/* This hover effect is only for desktop */
@media (min-width: 600px) {
  .portfolio-wrapper
    .portfolio-item-wrapper
    .portfolio-link:hover
    .portfolio-item
    .portfolio-thumbnail-wrapper
    .portfolio-hover {
    opacity: 1;
    .portfolio-hover-content {
      width: calc(100% - 1rem);
      height: calc(100% - 1rem);
      top: 0.5rem;
      left: 0.5rem;
    }
  }
}

/* This hover effect is annoying on mobile */
@media (max-width: 600px) {
  .portfolio-wrapper
    .portfolio-item-wrapper
    .portfolio-link
    .portfolio-item
    .portfolio-thumbnail-wrapper
    .portfolio-hover {
    display: none;
  }
}

.portfolio-modal {
  & .modal-dialog {
    margin: 0;
    max-width: 100vw;

    & .modal-content {
      text-align: center;
      overflow: hidden scroll;
      position: relative;
      display: flex;
      flex-direction: column;
      width: 100%;
      height: 100vh;
      max-width: 96rem;
      margin: auto;
      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;

      & .close-modal {
        top: auto;
        bottom: 1rem;
        left: 50%;
        margin-left: -1.5rem;
        padding: 0;
        right: auto;
        border: none;
        width: 3rem;
        height: 3rem;
        cursor: pointer;
        background-color: rgba(100 100 100 / 0.7);
        color: #fff;
        font-size: 1.5rem;
        line-height: 0;
        border-radius: 100%;
        z-index: 9;
        transition: all 0.2s;
        position: fixed;
        display: flex;
        justify-content: center;
        align-items: center;
        font-family: sans-serif;

        &:hover {
          opacity: 0.3;
          transform: rotate(45deg);
        }
      }

      & img {
        margin-bottom: 2rem;
      }
    }
  }
}

@media (min-width: 700px) {
  .portfolio-modal {
    & .modal-dialog {
      height: 100vh;
      margin: 1rem;
      & .modal-content {
        height: auto;
        & .close-modal {
          position: absolute;
          top: 1.5rem;
          bottom: auto;
          right: 1.5rem;
          left: auto;
          margin: 0;
        }
      }
    }
  }
}

/* load more button */
.btn-load-more {
  border: none;
  width: 100%;
  padding: 1rem;
  font-family: var(--font-family-sans-serif);
  font-size: 2rem;
  background: var(--galaxy-bg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  color: #ddd;
}

.footer {
  text-align: center;
  font-size: 0.9rem;
  font-family: var(--font-family-sans-serif);
  background: #000;
  transform: translateZ(-1px);
}

/* custom scrollbar */
/* ::-webkit-scrollbar {
  width: 5px;
}

::-webkit-scrollbar-track {
  background-color: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: #d6dee1;
  border-radius: 6px;
  border: 6px solid transparent;
  background-clip: content-box;
}

::-webkit-scrollbar-thumb:hover {
  background-color: #a8bbbf;
} */
