@import url('https://fonts.googleapis.com/css2?family=Arsenal:ital,wght@0,400;0,700;1,400;1,700&family=DM+Serif+Display:ital@0;1&family=Manrope:wght@200..800&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
  --h-font: "DM Serif Display", serif;
  --p-font: "Poppins", "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans",
    Geneva, Verdana, sans-serif;

  /* general */
  --trans-def: 300ms ease;

  /* nav settings */
  --home-nav-bg: rgb(0, 0, 0, 0);

  /* hero settings */
  --hero-overlay: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.11),
    rgba(0, 0, 0, 0.22),
    rgba(0, 0, 0, 0.11)
  );
  --search-bg: rgb(0, 0, 0, 0.3);
  --search-txt-clr: #fff;
  --search-btn-bg: #fff;
  --search-btn-txt: #000;
  --hvr-search-btn-bg: var(--si-primary-color);
  --hvr-search-btn-txt: #fff;

  /* container settings */
  --content-sm: 900px;
  --content-md: 1140px;
  --content-lg: 1440px;

  /* spacing-settings */
  --section-spacing: 100px;
  --content-padding: 24px;

  --spacing-xs: 1rem;
  --spacing-sm: 2rem;
  --spacing-md: 5rem;
  --spacing-lg: 7.5rem;
  --spacing-xl: 10rem;
  --spacing-xxl: 15rem;
}

* {
  min-width: 0;
}

body *:is(p, li, a, label, legend, button, option, input, ::placeholder) {
  font-family: var(--p-font) !important;
}

body *:is(h1, h2, h3, h4, h5, h6, .text-hero) {
  font-family: var(--h-font) !important;
}

/* resets */
body.home {
  padding-top: 0;
}

@media (min-width: 992px) {
  .home .featured .featured-gallery {
    margin-bottom: 0;
  }
}

/* hide default hero */

/* nav */
.home.translucent-header header:not(.reduced) {
  background-color: var(--home-nav-bg);
}
.home.translucent-header header {
  background-color: #fff;
}

header {
  height: auto;
  -webkit-transition: 300ms ease;
  transition: 300ms ease;
}

header .container {
  max-width: 100%;
  width: 100%;
  padding-inline: 1rem;
  padding-block: 2rem;
  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;
}

.home.translucent-header header:not(.reduced) .container {
  padding-bottom: 10rem;
}

@media screen and (min-width: 768px) {
  header .container {
    padding-inline: 5rem;
  }
}

header .logo {
  width: auto !important;
  height: 10rem !important;
  left: 1rem;
  top: 0;
  /* -webkit-transform: translateY(-50%);
  transform: translateY(-50%); */
}

@media screen and (min-width: 768px) {
  .home.translucent-header header:not(.reduced) .logo {
    height: 15rem !important;
  }
}

@media screen and (max-width: 479px) {
  header .logo {
    width: 150px;
  }
}

@media screen and (max-width: 767px) {
  header .logo {
    height: auto !important;
    left: 1rem;
    margin-top: 20px;
    width: 200px;
  }
}

@media screen and (max-width: 991px) {
  header .logo {
    height: 10rem !important;
    line-height: normal;
  }
}

@media screen and (min-width: 768px) {
  header .logo {
    left: 5rem;
  }
}

header nav > ul > li > a,
header nav .dropdown li a {
  text-transform: uppercase;
  font-weight: 400;
}

header nav > ul > li > a {
  font-size: 0.9em;
  letter-spacing: 1px;
}

header.reduced nav > ul > li > a,
header.reduced .sub-nav > li > a,
header.reduced .sub-nav > li.lang:not(.open) i.fa-angle-down,
header.reduced .sub-nav > li > a,
header.reduced a[data-toggle="auth-state"] > span,
header.reduced nav .menu-button {
  color: #6f6f6f;
}

header.reduced nav > ul > li:hover > a {
  color: #fff;
}

header.reduced nav .li-overlay > a .bar {
  background-color: #6f6f6f;
}

header nav .dropdown li a {
  font-size: 0.85em;
}

.more-menu-overlay .col-main .links ul > li > a {
  text-transform: uppercase;
  font-weight: 400;
  letter-spacing: 1px;
}

/*  */
/* hero */
/*  */

.home.translucent-header #customHero {
  margin-top: 0 !important;
  padding-top: 0;
}

.home.translucent-header #customHero::before {
  display: none;
}

#customHero {
  position: relative;
  z-index: 1;
}

#customHero::after {
  content: "";
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-image: var(--hero-overlay);
}

#customHero {
  padding: 0;
  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;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  min-height: calc(100vh);
  background: var(--si-hero-image) center center no-repeat !important;
  background-size: cover !important;
}

#customHero .hero_wrapper {
  width: 100%;
  height: 100%;
  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;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  z-index: 3;
}

#customHero .hero_wrapper .hero_content {
  width: min(1024px, 100%);
}

#customHero .hero_wrapper .hero_content .hero_header {
  margin-bottom: 0.5em;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-wrap: balance;
  font-size: 45px;
}

#customHero .hero_wrapper .hero_content .hero_header span.sub_header {
  display: block;
  font-size: 0.35em;
  letter-spacing: 2px;
  font-family: var(--p-font) !important;
}

#customHero .hero_wrapper .hero_content .hero_header span.sub_header.btm {
  margin-top: 1rem;
}

#customHero .hero_wrapper .hero_content .hero_header span.sub_header.top {
  margin-bottom: 1rem;
}

#customHero .listings-count {
  display: none;
}

/*  */
/* CONTENT */
/*  */

/* spacing */

.section-spacing,
.home section.padding {
  padding-block: var(--section-spacing);
}

.content-spacing {
  padding-block: var(--section-spacing);
}

.content-padding {
  padding-inline: var(--content-padding);
}

.home .override-top {
  margin-top: calc((var(--section-spacing) + 5rem) * -1);
  z-index: 5;
  position: relative;
}

@media (max-width: 768px) {
  .section-spacing,
  .home section.featured.padding {
    padding-block: calc(var(--section-spacing) / 2);
  }
}

/* container tools */

[class*="--contain"] {
  container-type: inline-size;
  width: var(--_content-size, 100%);
  margin-inline: auto;
}

.--contain-sm {
  --_content-size: min(var(--content-sm), 100%);
}

.--contain-md {
  --_content-size: min(var(--content-md), 100%);
}

.--contain-lg {
  --_content-size: min(var(--content-lg), 100%);
}

.--contain-full {
  --_content-size: 100%;
}

.--grid-1 {
  display: grid;
}

.--grid-2 {
  display: grid;
}

.--grid-2-full {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.--grid-3 {
  display: grid;
}

.--grid-3-full {
  display: grid;
}

.--grid-4 {
  display: grid;
}

.--grid-5 {
  display: grid;
}

@container (min-width: 768px) {
  .--grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .--grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .--grid-3-full {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .--grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .--grid-5 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@container (min-width: 1024px) {
  .--grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .--grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .--grid-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}
/* footer */
footer .footer-content ul.social li a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 8px;
}

/* headers   */
.home h2.cheader,
.blog > div > h2,
.featured > div > h2 {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 1px;
  margin-bottom: 1.25em;
  padding-bottom: 0.5em;
  position: relative;
  text-wrap: balance;
}

.home h2.cheader::after,
.blog > div > h2::after,
.featured > div > h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 5px;
  background-color: var(--si-primary-color);
}

.home h2.cheader {
  text-align: left;
}

h2.cheader.--center {
  text-align: center;
}

h2.cheader.--center::after,
.blog > div > h2::after,
.featured > div > h2::after {
  left: 50%;
  transform: translate(-50%);
}

@media (min-width: 768px) {
  .home h2.cheader,
  .blog > div > h2,
  .featured > div > h2 {
    font-size: 32px;
  }
}

@media (max-width: 767px) {
  .home h2.cheader,
  .blog > div > h2,
  .featured > div > h2 {
    font-size: 32px;
    text-align: center;
  }

  .home h2.cheader::after {
    left: 50%;
    transform: translate(-50%);
  }
}
