/*
Theme Name: Primack
Theme URI: https://702pros.com
Template: hello-elementor
Author: 702 Pros Team
Author URI: https://702pros.com
Version: 3.0.1.1719257269
Updated: 2024-06-24 19:27:49

*/

/* Globals */
:root {
  --green: #54655d;
  --gray: #e3e7e8;
  --transparent-white: #ffffffaa;
  --brown: #aea095;
  --blue: #22252c;
  --primary-black: #000000;
  --primary-black-transparent: #000000dd;
  --primary-black-transparent-hover: #121212dd;
  --blur-px: 8px;
}

html {
  --wp-admin--admin-bar--height: 32px;
  scroll-padding-top: var(--wp-admin--admin-bar--height);
}
* {
  font-family: "Oswald", sans-serif;
  box-sizing: border-box;
  color: var(--blue);
}
:focus-within {
  outline: none;
}
h1,
h2,
h3 {
  margin: 0 !important;
  padding: 0 !important;
  font-weight: 500 !important;
  letter-spacing: -1px;
  text-transform: uppercase;
}
h1 {
  font-size: 50px;
}
h2 {
  font-size: 42px;
}
h3 {
  font-size: 34px;
}
p {
  font-size: 24px;
  line-height: 34px;
  font-weight: 300;
}
strong {
  font-size: 24px;
  line-height: 34px;
  font-weight: 500;
  text-transform: uppercase;
}
body {
  overflow-x: hidden;
  color: #fff;
  padding: 0 !important;
  margin: 0 !important;
  position: relative;
}
.dark_txt {
  color: var(--blue);
}
.light_txt {
  color: #ffffff;
}
.light_container {
  background-color: var(--gray);
}
[type="submit"] {
  cursor: pointer;
}
flex,
flexbox {
  display: flex;
}
.lnk_absolute {
  position: absolute;
  height: 100%;
  width: 100%;
}
grid {
  display: grid;
}
.grid_column_4 {
  grid-template-columns: repeat(4, 1fr);
}
.gap_15 {
  gap: 15px;
}
body,
h1,
p {
  margin: 0;
  padding: 0;
}
label {
  font-weight: 600;
}
:is([type="text"], [type="email"], [type="tel"], select, textarea) {
  font-size: 24px;
  padding: 10px 15px;
}
/* End Globals */
.btn,
.btns a:nth-child(2),
.listing-filters form [type="submit"] {
  text-decoration: none;
  display: flex;
  font-size: 24px;
  line-height: 22px;
  font-weight: 400;
  text-transform: uppercase;
  /* min-width: 300px !important; */
  /* width: max-content; */
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  -moz-transition: all 200ms ease-in;
  -webkit-transition: all 200ms ease-in;
  -o-transition: all 200ms ease-in;
  transition: all 200ms ease-in;
  user-select: none;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  padding: 20px 36px;
  border: none;
  height: min-content;
  position: relative;
}
.cta_transparent {
  color: #fff;
  border: 1px solid #fff;
  backdrop-filter: blur(var(--blur-px));
  background-color: var(--primary-black-transparent);
}
.cta_transparent:hover {
  background-color: var(--primary-black-transparent-hover);
}
.abs_lnk {
  position: absolute;
  height: 100%;
  width: 100%;
  z-index: 5;
}
.cta,
.btns a:nth-child(2),
.listing-filters form [type="submit"] {
  background-color: var(--green) !important;
  color: #fff;
  border: none;
  transition: all 200ms ease;
  position: relative;
}
.cta:hover,
.btns a:nth-child(2):hover,
.listing-filters form [type="submit"]:hover {
  background-color: var(--blue) !important;
}
.alt_cta {
  color: #000;
  background-color: var(--gray);
  transition: all 200ms ease;
}
.alt_cta:hover {
  background-color: var(--blue);
  color: #fff;
}
.brown_cta {
  color: #000;
  background-color: var(--brown);
  transition: all 200ms ease;
}
.brown_cta:hover {
  background-color: var(--gray);
}
.align_items_center {
  align-items: center;
}
.justify_content_center {
  justify-content: center;
}
.gap_30 {
  gap: 30px;
}
container {
  display: block;
  max-width: 1300px;
  margin: auto;
  padding: 50px 15px;
}
header .main_nav .btn {
  font-size: 18px;
  line-height: 15px;
}
.nav-socials {
  text-decoration: none;
}
.right_flex_header {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 15px;
}
.service-list ul {display:flex;flex-direction: column;gap:18px;margin: 20px 0 0 ;}
.service-list li{padding: 20px; border-radius: 5px; background: #fff;border:1px solid #00000055;}
.max_container {
  max-width: 1600px;
  margin: auto;
  padding: 0;
}
.alt_max_container {
  max-width: 100%;
}

.header_container {
  position: relative;
  width: 100%;
  height: 100%;
  max-height: 260px;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.header_container h1 {
  font-weight: 500 !important;
}

.overlay {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: linear-gradient(to right, #000000dd 600px, #00000022);
  pointer-events: none;
  z-index: 1;
}

.header_container img {
  position: absolute;
  object-fit: cover;
  object-position: center;
  min-width: 100%;
  height: 100%;
  filter: saturate(1.25);
}

.header_container div {
  z-index: 2;
}

.what_we_do {
  height: 500px;
  border-radius: 0;
  background-size: cover !important;
  background-position: top center !important;
  display: flex;
  padding: 35px;
  align-items: center;
  justify-content: center;
  transition: all 200ms ease-in;
  position: relative;
  z-index: 0;
}
.what_we_do:hover {
  transform: scale(1.03);
  z-index: 1;
  box-shadow: none;
}
.what_we_do .btn {
  font-size: 20px;
  transition: ease 200ms;
}
.what_we_do:hover .btn {
  background: #000000aa;
}
.grid_column_2 {
  grid-template-columns: repeat(2, 1fr);
  cursor: pointer;
}
.events_return {
  text-decoration: none;
  color: var(--primary-gold);
  font-size: 28px;
  display: inline-block; /* Allows the transform property to work */
  transition: transform 0.3s ease; /* Smooth transition for the transform effect */
}
.events_return:hover {
  transform: translateX(-10px); /* Moves the arrow 10px to the left on hover */
}

.post_id_23 .mi_23,
.post_id_25 .mi_25,
.post_id_28 .mi_28,
.post_id_30 .mi_30 {
  background-color: #eee;
}
header {
  color: #fff;
  background-color: var(--green);
  position: relative;
  z-index: 5000;
  padding: 5px 0;
}
header flex {
  align-items: center;
  justify-content: center;
}
.main_nav ui {
  display: inline-flex;
}
.dropdown:after {
  content: "";
  display: block;
  height: 13px;
  width: 13px;
  background-size: contain;
  background-image: url("https://flyertap.com/wp-content/uploads/2024/04/9126125.png");
}

.main_nav {
  width: 100%;
}

nav ul {
  display: flex;
  gap: 7px;
  list-style-type: none;
  margin: 0;
  padding: 0;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

/* General Menu Styles */
.custom-nav {
  /*background-color: #333;*/
  /*padding: 10px;*/
}

.custom-nav .menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
}

.custom-nav .menu-item {
  position: relative;
}

.custom-nav .menu-item a {
  text-decoration: none;
  color: #fff;
  padding: 10px 15px;
  display: flex;
  justify-content: center;
  transition: background-color 0.3s;
}

.custom-nav .menu-item a:hover {
  background: #00000029;
}

/* Dropdown Styles */
.custom-nav .submenu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background-color: var(--green);
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 150px;
  z-index: 1000; /* Ensure dropdown is on top */
}

.custom-nav .submenu li {
  /*border-bottom: 1px solid #555;*/
  border: none;
  padding: 10px 0px 10px 0px;
}

.custom-nav .submenu li a {
  color: #fff;
  /*padding: 10px;*/
  text-transform: uppercase;
}

.custom-nav .submenu li a:hover {
  background-color: #555;
}

/* Show Dropdown on Hover */
.custom-nav .menu-item:hover .submenu {
  display: block;
}

.btns a:nth-child(1) {
  color: var(--blue) !important;
  padding: 0 !important;
  min-width: unset !important;
  width: 100% !important;
  border: 2px solid var(--blue);
  transition: all 200ms ease;
}
.btns a:nth-child(1):hover {
  color: var(--green) !important;
  border: 2px solid var(--green);
}
.footer_nav a,
.nav_a,
.btns a:nth-child(1) {
  justify-content: center;
  text-decoration: none;
  display: flex;
  font-size: 24px;
  font-weight: 400;
  color: #fff;
  user-select: none;
  text-transform: uppercase;
  cursor: pointer;
  align-items: center;
  position: relative;
  transition: all 250ms ease;
  padding: 5px 0;
  min-width: 100px;
}
.footer_nav a:hover:after,
.nav_a:hover:after,
.slider_info_a:hover:after {
  content: "";
  width: 100%;
  transform: scalex(1);
  z-index: 5;
}

.footer_nav a:after,
.nav_a:after,
.slider_info_a:after,
.btns a:nth-child(1):after {
  content: "";
  background: #fff;
  height: 2px;
  width: 100%;
  transform: scalex(0);
  transform-origin: left bottom;
  display: block;
  transition: ease 250ms;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 5;
}

.dropdown.dp_active {
  background-color: #eee;
}
.dropdown.dp_active:after {
  -moz-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg);
}
.dropdown_menu {
  font-size: 14px;
  background-color: #fff;
  position: absolute;
  width: max-content;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  flex-direction: column;
  visibility: hidden;
  -moz-box-shadow: 0 0 20px #00000022;
  -webkit-box-shadow: 0 0 20px #00000022;
  -o-box-shadow: 0 0 20px #00000022;
  box-shadow: 0 0 20px #00000022;
  right: 0;
  padding: 15px;
}
.dropdown_menu a:hover {
  background-color: #eee;
}
.flex_container_70_30 {
  display: flex;
  gap: 25px;
  align-items: center;
  height: 100%;
  width: 100%;
}

.flex_70 {
  display: flex;
  flex-direction: column;
  flex: 0 0 70%;
  justify-content: space-evenly;
  height: 100%;
}
.flex_30 {
  display: flex;
  flex-direction: column;
  flex: 0 0 30%;
  justify-content: center;
  align-items: center;
  height: 100%;
}
.flex_1 {
  flex: 1;
}
.flex_50 {
  flex: 0 0 50%;
}
.pad_50_0 {
  padding: 50px 0;
}
.pad_100_0 {
  padding: 100px 0;
}
.pad_25_0 {
  padding: 25px 0;
}
.max {
  max-width: 1600px;
  width: 100%;
  margin: auto;
  padding: 0 15px;
}
.justify_between {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Hero */
.hero {
  height: 100%;
  width: 100%;
  max-width: 1200px;
  max-height: 600px;
  padding: 50px;
  margin: 0 0 50px 5px;
  background-color: var(--transparent-white);
  backdrop-filter: blur(var(--blur-px));
}
.hero_slider_container {
  background-color: var(--gray);
  color: #fff !important;
  padding: 0;
  display: flex;
  align-items: center;
  height: 100vh;
}
.hero_container {
  height: 100%;
  max-height: 92vh;
  background-image: url(/wp-content/uploads/2024/09/las-vegas-nevada-usa-skyline-at-dusk-2023-11-27-05-16-27-utc-scaled.jpg);
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  position: relative;
}
.hero_overlay {
  position: absolute;
  height: 100%;
  width: 100%;
  box-shadow: inset 400px 0 140px #000000aa;
}

.hero_content {
  height: 100%;
  max-width: 1600px;
  margin: auto;
  display: flex;
  align-items: center;
}

.hero_btns {
  display: flex;
  align-content: center;
  gap: 10px;
}

/* Property */
.main-listings-page {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.property_content,
.all-listings {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 25px;
  width: 100%;
}
.all-listings {
  width: 50%;
}
.property_card,
.listing-item {
  min-width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 50px;
  align-items: center;
  gap: 15px;
  background-color: #fff;
  color: var(--blue);
}
.property_info,
.details {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: var(--blue);
}
.btns {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}
.property_info .brown_cta {
  width: 100%;
}
.property_info flex {
  flex-wrap: wrap;
}
.property_address {
  margin: 0 0 10px 0;
}
.details span {
  font-size: 24px;
  line-height: 34px;
  font-weight: 300;
}
.beds,
.baths {
  margin-left: 10px;
}
.beds {
  margin-right: 25px;
}
.property_img,
.list-img {
  width: 100%;
  height: 300px;
  overflow: hidden;
  position: relative;
}
.property_img img,
.list-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.listing-filters {
  width: 100%;
}
.listing-filters form {
  width: 100%;
  display: flex;
  gap: 5px;
}
.listing-filters form select {
  width: inherit;
  border: 0 !important;
}
.listing-filters form option {
  border: 0 !important;
}
#googlemap {
  height: 650px !important;
  align-self: center;
  flex: 0 0 49%;
  padding: 2em;
}
/* End Property */

/* Residential */
.residential_container {
  display: flex;
  height: 85vh;
  width: 100%;
}
.residential_container .flex_50 {
  overflow: hidden;
}
.residential_container .flex_50 img {
  object-fit: cover;
  object-position: 40% center;
  height: 100%;
  width: 100%;
}
.residential_content {
  margin: auto;
}
.residential flex {
  margin-top: 25px;
  gap: 25px;
}
.residential {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 0 50px;
}
/* End Residential */
#bna {
  height: 100%;
  position: relative;
}
.bna_nav {
  filter: invert(1);
  display: flex;
}
#slider {
  display: flex;
  align-items: center;
  gap: 20px;
  overflow: hidden;
  width: 100%;
  height: 100%;
  position: relative;
}
.slide {
  position: relative;
  display: flex;
  /*align-items: center;*/
  min-width: 100%;
  height: 100%;
}
.slider_info_content {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  max-width: 540px;
  height: 100%;
  max-height: 560px;
  gap: 30px;
  padding: 50px;
  top: 50;
  left: 50;
  z-index: 40;
  background-color: var(--primary-black-transparent);
  backdrop-filter: blur(14px);
  transform: translateX(30%);
  opacity: 0;
  transition: transform 500ms ease-out, opacity 500ms ease-out;
}
.slide.in-view .slider_info_content {
  transform: translateX(0);
  opacity: 1;
}
.slider_info_content h2 {
  font-weight: 100 !important;
  text-transform: uppercase !important;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  font-size: 68px;
  line-height: 60px;
}
.slide.in-view h2 {
  opacity: 1;
}
.slider_info_a {
  color: #fff;
  text-decoration: none;
  font-weight: 300 !important;
  position: relative;
  background: transparent;
  border: 0;
  padding: 5px 0;
  margin: 15px 0 0 5px;
  min-width: 0;
  width: fit-content;
  text-transform: uppercase;
  line-spacing: 10px;
  letter-spacing: 6px;
}
.slider_info_controls {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 30px;
  justify-content: space-between;
  align-items: start;
}
.slide_img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.scroll_left,
.scroll_right {
  transition: all 200ms ease;
  padding: 15px;
}
.scroll_left img,
.scroll_right img {
  height: 30px;
  width: 30px;
}
.scroll_left {
  transform: rotate(180deg);
}
.scroll_left:hover {
  transform: rotate(180deg) scale(1.05);
  cursor: pointer;
}
.scroll_right:hover {
  cursor: pointer;
  transform: scale(1.05);
}
/* End Hero */
/* Primary Containers */
.container_primary {
  background-color: #000;
  color: #fff !important;
  padding: 150px 0;
}
.black_container_primary {
  background-color: var(--primary-black);
  color: #fff !important;
  padding: 150px 0;
}
/* End Primary Containers */
.mission_container_content {
  margin: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
  align-items: center;
}
.sponsor_container_content {
  margin: auto;
  display: grid;
  grid-template-columns: repeat(1, 2fr);
  justify-content: center;
  align-items: center;
}
.gray_container {
  width: 100%;
  background-color: var(--gray);
}
#about_dropdown.show_popup,
#sponsor_dropdown.show_popup {
  visibility: visible;
}
.main-content {
  margin: 20px;
}

/* End Hero */

/* Banners */
.banner_lg {
  width: 100%;
  height: 100%;
  max-height: 450px;
  background-color: var(--blue) !important;
}

.banner_heading {
  background-color: var(--green);
}
/*-------------------------
    SERVICES PAGE STYLING
---------------------------*/
.header_container {
  display: flex;
	min-height: 450px;
}
.header_container h1 {
  font-size: 36px !important;
  text-transform: none;
}
.col-container-1 {
  width: 100%;
}
.header-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-left: 10%;
}
.header-content {
  height: min-content;
  width: 100%;
  padding: 50px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: rgb(255, 255, 255, 0.8);
}
.card-heading h1 {
}

.card-heading .header-span {
  color: transparent;
  -webkit-text-stroke: 1px #fff;
  font-size: 8.25vw;
}

.text-divider {
  height: 10px;
  width: 100px;
  background-color: var(--green);
  margin-top: 30px;
  margin-bottom: 30px;
}

.card-text p {
  text-align: left;
  color: #000;
  /*font-weight: 500;*/
}

/*.card-heading:after {
        content: "";
        position: absolute;
        height: 1px;
        width: 100%;
        background-color: var(--green);
        bottom: 0;
    }*/

.col-container-2 {
  height: 100%;
  width: 100%;
}
/*----------------------------
    OVERVIEW SECTION STYLING
-----------------------------*/
.ov-section {
  overflow: hidden;
}
.skewed-bg {
  background: var(--blue);
  padding: 300px 0;
  transform: skew(0deg, -10deg);
  margin-top: -170px;
}
.skewed-bg .content {
  transform: skew(0deg, 10deg);
  /*text-align: center;*/
  display: flex;
  align-items: center;
}
.skewed-bg .content .title {
  padding-top: 100px;
  font-weight: normal;
}
.skewed-bg .content .text {
  /*width: 60%;*/
  margin: 25px auto;
  color: #ccfff2;
}

.bottom {
  padding-top: 300px;
  background: var(--brown);
}
.bottom .credits {
  text-align: center;
  color: #666;
}
.bottom .credits .link {
  color: #00b285;
  text-decoration: none;
}

.ov-content {
  display: flex;
  background: var(--blue);
}

.ov-text-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.ov-text {
  width: 50%;
}

.ov-text > .ov-heading > h2 {
  color: var(--gray);
  font-size: 2rem;
}

/*.ov-text > .ov-heading > h2 > .ov-span {

}*/

.ov-subtext p {
  margin-top: 10px;
  color: var(--gray);
}

.ov-img-container {
  height: 100%;
  width: 100%;
  transform: scale(0.75);
}

.ov-img {
  height: 100%;
  width: 100%;
}

.overview_section {
  position: relative;
  z-index: 2;
  padding: 0;
  background: var(--brown);
}

.overview-overlay {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: linear-gradient(to right, #000000dd 600px, #00000022);
  pointer-events: none;
  z-index: 1;
}

.overview-col-containers {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
}

.overview_section .col-container-1 {
  display: flex;
  height: 100%;
  width: 100%;
}

.overview-card {
  margin-right: 10%;
  display: flex;
  border-right: 3px solid var(--green);
}

.overview-content {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: 100%;
  text-align: right;
  padding-right: 25px;
}

.overview-content > .card-heading h2 {
  color: var(--green);
  line-height: 0.9;
  font-size: 3.75vw !important;
}

.overview-content > .card-text p {
  color: black;
  text-align: right;
  line-height: inherit;
}

.overview-content .card-heading .overview-span {
  font-size: 8.25vw;
  color: black;
}

.col-img {
  height: 100%;
  width: 100%;
}

/*---------------------------------------
    SERVICES STYLING
-----------------------------------------*/
.services-section{background: var(--gray);}
.service {padding: 50px 25px;max-width: 1400px;margin:auto;}

.img-content-container {
  width: 100%;
  display: flex;
  align-items: center;
}

.images {
  display: grid;
  justify-items: center;
}

.img-container {
}

.service-img {
  width: 100%;
  box-shadow: 5px 10px 8px #888888;
  /*position: relative;
    z-index: 1;*/
}

.text-content-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  padding: 20px;
}

.content-heading h1 {
  line-height: 1;
}

.content-heading h1 span {
  font-weight: 800;
  font-size: 7.5rem;
}

.service-list h2 {
  font-size: 28px;
  text-transform: none;
}
.service-list p {margin-top: 25px;}
.flipIn,
ul li,
h1 {
  animation: flipdown 0.5s ease both;
}

.no-select,
h2 {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

ul {
  list-style: none;
  perspective: 900;
  padding: 0;
  margin: 0;
}

ul li {
  position: relative;
  padding: 0;
  margin: 0;
  padding-bottom: 20px;
  padding-top: 20px;
}
ul li i {
    position: absolute;
    top: 35px;
    right: 35px;
}

ul li i:before,
ul li i:after {
  content: "";
  position: absolute;
  background-color: #000;
  width: 2px;
  height: 9px;
}
ul li i:before {
  transform: translate(-2px, 0) rotate(45deg);
}
ul li i:after {
  transform: translate(2px, 0) rotate(-45deg);
}
ul li input[type="checkbox"] {
  position: absolute;
  cursor: pointer;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 0;
}
ul li input[type="checkbox"]:checked ~ p {
  margin-top: 0;
  max-height: 0;
  opacity: 0;
  transform: translate(0, 50%);
}
ul li input[type="checkbox"]:checked ~ i:before {
  transform: translate(2px, 0) rotate(45deg);
}
ul li input[type="checkbox"]:checked ~ i:after {
  transform: translate(-2px, 0) rotate(-45deg);
}
/*--------------------------------------------
    LISTING STYLING
----------------------------------------------*/
.listing-sec {
  display: flex;
  flex-direction: row;
  background: white;
  border: 1px solid var(--blue);
  border-radius: 10px;
}

.apfl-column {
}

.apfl-two-fifth {
  width: 33.33%;
}

.apfl-three-fifth {
  width: 66.66%;
  border-left: 1px solid var(--blue);
}

.lst-dtls {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 20px;
}
.details-left {
  width: 66.66%;
}

.details-right {
  width: 33.33%;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.bed-bath-std {
}

.bed-bath-std img {
  padding: 10px;
}

.apfl-column .desctitle,
.apfl-column .desc {
  padding: 20px;
}

.extra-half h4 {
  padding-left: 10px;
}

.extra-half ul li {
}

.extra-half ul .list__item {
  padding-left: 10px;
}

.apfl-half a {
  padding-right: 10px;
  text-decoration: none;
  font-weight: 700;
}

.apfl-three-fifth .apfl-half p {
  padding-right: 10px;
}

/* grid */
.row {
}

@media all and (min-width: 600px) {
  /* set col widths */
  .col-2-3 {
    width: 66.66%;
  }
  .col-1-2 {
    width: 50%;
  }
  .col-1-3 {
    width: 33.33%;
  }
  .col-1-4 {
    width: 25%;
  }
  .col-1-8 {
    width: 12.5%;
  }
}

/* End Banners */

#main flex {
  flex-wrap: wrap;
  gap: 15px;
}
#main flex div {
  height: 450px;
  overflow: hidden;
  width: 400px;
  flex: 1 1 400px;
}
#main flex div img {
  height: 100%;
  width: 100%;
  cursor: pointer;
  object-fit: cover;
  object-position: top center;
}

/* Las Vegas Platform */
.platform_container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 50px;
  padding: 0 25px;
}
.platform_grid {
  display: grid;
  grid-template-rows: repeat(2, 1fr);
  gap: 100px;
}
.platform_grid_top {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
.platform_grid_bottom {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
.platform_grid_bottom .platform_grid_item div img {
  object-position: center 20%;
}
.platform_grid_item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-decoration: none;
  color: #fff;
  transition: all 200ms ease;
}
.platform_grid_item div {
  overflow: hidden;
  height: 100%;
  max-height: 700px;
  width: 100%;
}
.platform_grid_item div img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: all 200ms ease;
}
.platform_grid_item h2 {
  font-size: 23px;
  line-height: 34px;
  font-weight: 300;
  text-transform: uppercase;
  backdrop-filter: blur(16px);
  margin-top: -92px !important;
  width: 100%;
  display: flex;
  padding: 19px 29px !important;
  background: linear-gradient(45deg, #0000002b, #00000000);
}
.platform_grid_item:hover div img {
  transform: scale(1.03);
}
/* End Las Vegas Platform */

/* Clients */
.clients_container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 100px;
}
.clients_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  width: 100%;
}
.clients_page_grid {
  display: grid;
  grid-template-columns: repeat(3, 3fr);
  gap: 60px;
  width: 100%;
  height: 100%;
}
.clients_grid_item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  position: relative;
  text-decoration: none;
  color: #fff;
  height: 100vh;
  overflow: hidden;
}
.clients_grid_item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, #000 90px, #00000044 900px);
  z-index: 1; /* Ensure it sits above the element content */
  pointer-events: none; /* Allow clicks to pass through */
}
.clients_grid_item div {
  position: absolute;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-width: 600px;
  justify-content: center;
  z-index: 1;
  padding: 50px;
  backdrop-filter: blur(20px);
  max-width: min-content;
}
.clients_grid_item_lnk {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 2;
}
.clients_grid_item div h1 {
  line-height: 58px;
  font-weight: 100 !important;
}
.clients_grid_item div a {
  font-weight: 300 !important;
  position: relative;
  background: transparent;
  border: 0;
  padding: 5px 0;
  margin: 15px 0 0 5px;
  min-width: 0;
  width: fit-content;
  text-transform: uppercase;
  line-spacing: 10px;
  letter-spacing: 6px;
}
.clients_grid_item div a:hover {
  background: transparent;
}
.clients_grid_item img {
  position: absolute;
  height: 100%;
  object-fit: cover;
  width: 100%;
  transition: all 20s ease;
}
.clients_grid_item:hover img {
  transform: scale(1.5); /* Scales the image on hover */
}
/* End Clients */

/* Services */
.services_content {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
.service_img_content {
  max-width: 500px;
  max-height: 400px;
  min-width: 500px;
  overflow: hidden;
}
.service_img {
  width: 100%;
  object-fit: cover;
  object-position: center;
  max-width: unset !important;
  display: block;
}

.service_content {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
/* End Services */

/* Banner */
.container_banner {
  background-color: var(--primary-gray);
  width: 100%;
  height: 450px;
  max-height: 450px;
  display: grid;
  grid-template-columns: 50% 50%;
  overflow: hidden;
}
.banner_text_content {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 50px;
}
.banner_text {
  height: max-content;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.banner_img {
  object-fit: cover;
  max-height: 450px;
  width: 100%;
}
/* End Banner */

/* Vegas Vibe */
.container_vibe {
  background-color: #000;
  color: #fff !important;
  height: 90vh;
  display: flex;
  justify-content: center;
  padding: 0 25px;
}
.content_vibe {
  width: 100%;
  max-height: 100%;
  display: flex;
  justify-content: center;
  gap: 150px;
}
.vibe_text_content {
  display: flex;
  justify-content: center;
  align-items: center;
}
.vibe_text {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.vibe_img {
  object-fit: contain;
  max-height: 100%;
}
.vibe_img_content {
  max-height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.vibe_logo {
  object-fit: contain;
  width: 100%;
}

.vibe_text ul li {
  font-size: 23px;
  line-height: 34px;
  font-weight: 300;
}
/* End Vegas Vibe */

/* Contact Container */
.contact-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin: auto;
  gap: 15px;
}

.contact-form :is(input, textarea) {
  width: 100%;
  border: none;
}

.contact-form textarea {
  resize: vertical;
}

.contact {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 1000px;
  justify-content: space-evenly;
  text-align: center;
}

/* End Contact Container */
.lone_txt {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 1000px;
  justify-content: space-evenly;
}

.page-numbers {
  text-decoration: none;
  border: 1px solid #ddd;
  display: flex;
  line-height: 16px;
  color: #000;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  margin: 0;
  padding: 14px;
}
.page-numbers:hover,
.page-numbers.current {
  color: #fff;
  background-color: #21448d;
  border-color: #21448d;
}
.pagination ul {
  display: flex;
  gap: 5px;
  list-style: none;
  margin: 45px 0;
  padding: 0;
}
.sponsor_img {
  display: flex;
  height: 380px;
  width: 100%;
  object-fit: cover;
  object-position: top center;
}
.sponsored_listings .sponsor_item {
  overflow: hidden;
  position: relative;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  flex: 0 400px;
  -moz-box-shadow: 0 0 40px #00000012;
  -webkit-box-shadow: 0 0 40px #00000012;
  -o-box-shadow: 0 0 40px #00000012;
  box-shadow: 0 0 40px #00000012;
}
.sponsored_listings a {
  display: flex;
  height: 100%;
  position: absolute;
  width: 100%;
}
.sponsored_listings {
  flex-wrap: wrap;
  gap: 25px;
}
.sponsored_listings .sponsor_item h3 {
  margin: 10px 0 0;
}
.sponsored_listings span {
  font-size: 18px;
  font-weight: 600;
}
.sponsor_item content {
  display: block;
  padding: 20px;
}
.sponsor_item {
  box-shadow: 0 0 20px #00000012;
}
.sponsor_item p {
  margin-top: 10px;
  font-size: 16px;
  line-height: 26px;
  font-weight: 500;
}
.anchor {
  padding-top: 80px;
}

.slider_info_content {
  opacity: 1 !important;
  transform: none !important;
  max-height: fit-content;
  height: unset;
}
.slider_info_content h2 {
  opacity: 1 !important;
}
.post_container {
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 100px;
}
.post_content {
  display: flex;
  height: 100%;
  width: 100%;
  align-items: center;
  justify-content: center;
}
.post_img {
  max-width: 60vw;
  height: 100%;
  max-height: 100vh;
  overflow: hidden;
}
.post_img img {
  object-fit: cover;
  aspect-ratio: 1/1;
  height: 100%;
}
.post {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 50px;
  margin-right: -85px;
  z-index: 10;
  max-width: 50vw;
  background-color: var(--primary-black-transparent);
  backdrop-filter: blur(var(--blur-px));
}
.post_alt {
  margin-right: unset;
  margin-left: -85px !important;
}

/* Thank You Scheduling Page Styling */
.thank-you-container {
  display: flex;
  width: 1400px;
  justify-self: center;
  flex-direction: column;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  padding: 25px;
  margin: 25px;
  height: 100%;
  width: 100%;
  max-width: 1200px;
  max-height: 600px;
  padding: 50px;
  /* margin: 0 0 50px 5px; */
  background-color: var(--transparent-white);
  backdrop-filter: blur(var(--blur-px));
}

.appointment-details {
  display: flex;
  gap: 20px;
  border-top: 1px solid var(--gray);
  padding: 25px 0;
  margin-top: 25px;
  justify-content: space-between;
}

.detail-row .detail-label {
  color: #b4b4b4;
}

.thank-you-container .thank-you-btns {
  margin-top: 30px;
  display: flex;
  gap: 20px;
  justify-content: center;
}

.thank-you-btns a {
  background-color: var(--green) !important;
  color: #fff;
  border: none;
  transition: all 200ms ease;
  position: relative;
  padding: 25px;
  text-decoration: none;
  text-transform: uppercase;
}

/* Mobile-First Responsive Styles */

@media (max-width: 480px) {
  .header_container {
    min-height: 150px;
  }

  .header-content {
    padding: 15px;
  }

  .card-heading h1 {
    font-size: 24px !important;
  }

  .service-list h2 {
    font-size: 18px !important;
  }

  .modal-content {
    padding: 10px;
  }

  .close-button {
    font-size: 24px;
    padding: 0 5px;
  }

  /* Improve touch targets */
  .preview-trigger {
    padding: 10px;
  }

  .close-button {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .thank-you-container {
    width: 95%;
    margin: 15px auto;
    padding: 20px;
    box-shadow: none; /* Remove shadow on mobile */
  }

  .thank-you-container h1 {
    font-size: 24px !important;
    line-height: 1.3;
  }

  .thank-you-container p {
    font-size: 16px !important;
  }

  .appointment-details {
    gap: 10px;
    padding: 15px 0;
  }

  .detail-row {
    flex-direction: column; /* Stack label and value */
    align-items: flex-start;
    gap: 5px;
  }

  .detail-row .detail-label {
    font-size: 14px;
  }

  .thank-you-btns {
    margin-top: 20px;
    gap: 10px;
  }

  .thank-you-btns a {
    padding: 15px;
    font-size: 16px;
  }
}

/* Print styles */
@media print {
  .pdf-modal,
  .preview-trigger {
    display: none;
  }

  .service-list ul li {
    break-inside: avoid;
  }
}

/* Accessibility improvements */
@media (prefers-reduced-motion: reduce) {
  .preview-trigger,
  .modal-content {
    transition: none;
  }
}

@media only screen and (max-width: 1348px) {
  .listing-filters form {
    display: flex !important;
    flex-wrap: wrap;
  }
}

/* Base Mobile Styles */
@media (max-width: 768px) {
  /* Typography */
  .property_card,	.listing-item {padding: 25px;}
  h1 {
    font-size: 32px !important;
    line-height: 38px !important;
  }

  h2 {
    font-size: 28px !important;
    line-height: 34px !important;
  }

  h3 {
    font-size: 24px !important;
    line-height: 30px !important;
  }

  p {
    font-size: 16px !important;
    line-height: 24px !important;
  }

  .header_container h1 {
    font-size: 28px !important;
  }

  .header-card {
    margin-left: 0;
    width: 100%;
    /*padding: 20px;*/
  }

  .card-heading h1 {
    font-size: 28px !important;
  }

  /* Overview section */
  .ov-section {
    padding: 20px 0;
  }

  .ov-content {
    padding: 15px;
    gap: 20px;
  }

  .ov-text-container {
    padding: 15px;
  }

  .ov-text > .ov-heading > h2 {
    font-size: 24px !important;
  }

  /* Service list */
  .service-list {
    padding: 0 15px;
  }

  .service-list h2 {
    font-size: 20px !important;
  }

  /* Modal adjustments */
  .modal-content {
    width: 95%;
    margin: 10px auto;
    padding: 15px;
  }

  .pdf-preview-container {
    margin: 10px 0;
  }

  .preview-image {
    max-width: 100%;
  }

  .header-content {
    padding: 20px;
  }

  /* Flex Containers */
  .flex_container_70_30 {
    flex-direction: column;
    gap: 30px;
  }

  .flex_70,
  .flex_30 {
    flex: 0 0 100%;
  }

  /* Residential Section */
  .residential_container {
    flex-direction: column-reverse;
    height: auto;
  }

  .residential_container .flex_50 {
    width: 100%;
    /*min-height: 300px;*/
  }

  .residential {
    padding: 30px 20px;
  }

  /* Services Section */
  .service {
    flex-direction: column;
    padding: 15px;
  }

  .service-img {
    width: 100%;
    margin-bottom: 20px;
  }

  .text-content-container {
    width: 100%;
    padding: 10px;
  }

  /* Team Section */
  .team-col {
    flex-direction: column !important;
    padding: 20px;
    text-align: center !important;
  }

  .team-img {
    width: 100%;
  }

  .box-text {
    width: 100%;
  }

  .team-col:nth-child(even) {
    text-align: center !important;
  }

  /* Contact Form */
  .contact-form flex {
    flex-direction: column;
  }

  .contact-form input,
  .contact-form textarea {
    width: 100%;
  }

  /* Property Cards */
  .property_card {
    flex-direction: column;
    padding: 15px;
  }

  .property_img {
    width: 100%;
    height: 200px;
  }

  .property_info {
    width: 100%;
  }

  /* Navigation */
  .main_nav {
    display: none;
  }

  #mobile_menu {
    display: flex;
    padding: 10px 0px !important;
  }

  /* Padding/Margin Adjustments */
  .pad_50_0 {
    padding: 30px 0;
  }

  .pad_100_0 {
    padding: 30px 20px;
  }

  container {
    padding: 30px 15px;
  }

  .footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 50px !important;
    text-align: center;
  }

  .footer_content {
    width: fit-content !important;
    align-items: center !important;
  }

  .footer_nav {
    align-items: center;
    width: fit-content;
  }

  .footer_nav a {
    justify-content: center !important;
  }
  .inline_submit {
    flex-direction: column;
    gap: 25px;
  }

  /* Listings Page Styling */

  .listing-filters {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .listing-filters form {
    flex-wrap: wrap;
    margin-bottom: 15px;
    place-content: center;
  }
  .listing-filters form [type="submit"] {
    margin-top: 20px;
  }
  #googlemap {
    height: inherit !important;
    min-width: 100%;
  }
  .all-listings {
    width: 100%;
  }
  .listing-item {
    display: flex;
    flex-direction: column;
  }
  .listing-item a {
  }
  .list-img img,
  #googlemap img {
    display: block !important;
  }
  .details {
    align-items: center;
    text-align: center;
  }
  .btns {
    padding: 25px 0;
    display: flex;
    flex-direction: column;
  }
  .btns a:nth-child(1) {
    padding: 5px !important;
  }

  /* About Page */
  .team-img {
    width: 100% !important;
    display: flex;
    flex-direction: column;

    gap: 20px;
  }
  .team-img img {
    height: fit-content !important;
  }
  .box-text {
    width: 100% !important;
  }
  .team-col {
    padding: 15px !important;
  }
}

/* Tablet Styles */
@media (min-width: 769px) and (max-width: 1024px) {
  /* Typography */
  h1 {
    font-size: 36px !important;
  }

  h2 {
    font-size: 32px !important;
  }

  /* Layout */
  .header_container {
    max-height: 300px;
  }

  .residential_container {
    height: auto;
  }

  .residential_container .flex_50 {
    min-height: 400px;
  }

  /* Property Cards */
  .property_card {
    flex-direction: row;
  }

  .property_img {
    width: 40%;
  }

  .property_info {
    width: 60%;
  }
  .ov-content {
    flex-direction: column;
  }

  .ov-text-container,
  .ov-img-container {
    width: 100%;
  }

  .ov-text {
    max-width: 100%;
  }

  .brochure-section-columns {
    flex-direction: column-reverse;
    text-align: center;
  }

  .brochure-section-columns > div {
    width: 100%;
  }
}

/* Large Screen Adjustments */
@media (min-width: 1025px) {
  .container {
    max-width: 1200px;
    margin: 0 auto;
  }
}

/* Print Styles */
@media print {
  .header_container,
  footer,
  .nav_container {
    display: none;
  }

  body {
    font-size: 12pt;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }
}

/* Utility Classes */
.hide-mobile {
  display: none !important;
}

@media (min-width: 768px) {
  .hide-mobile {
    display: block !important;
  }

  .hide-desktop {
    display: none !important;
  }
}

@media (max-width: 900px) {
  .post_container {
    gap: 50px;
    flex-direction: column;
    text-align: center;
  }
  .content_vibe {
    flex-direction: column;
  }
  .vibe_img_content {
    order: -1;
  }
  .post_img {
    max-width: 100vw !important;
  }
  .hero img,
  .max img {
    display: none;
  }

  .hero_container {
    /*height: 50%;*/
  }
  .hero {
    margin: 0 25px 0px 25px;
    width: -webkit-fill-available;
  }
  .flex_70,
  .flex_30 {
    align-items: center;
    text-align: center;
  }
  .residential {
    text-align: center;
  }
  .residential flex {
    display: flex;
    flex-direction: column;
  }

  .thank-you-container {
    width: 90%; /* More width on tablet */
    max-width: 800px;
    margin: 25px auto;
    padding: 30px;
    max-height: unset; /* Remove max height restriction */
  }

  .appointment-details {
    flex-direction: column; /* Stack details vertically */
    gap: 15px;
    padding: 20px 0;
  }

  .detail-row {
    width: 100%;
    justify-content: space-between;
  }

  .thank-you-btns {
    flex-direction: column; /* Stack buttons vertically */
    gap: 15px;
    width: 100%;
  }

  .thank-you-btns a {
    width: 100%; /* Full width buttons */
    text-align: center;
  }
}

@media (max-width: 1200px) {
  h1 {
    font-size: 48px;
    line-height: 48px;
    text-align: center;
  }
  h2 {
    font-size: 48px;
    line-height: 48px;
  }
  p {
    font-size: 20px !important;
  }
  .service_content {
    gap: 20px;
  }
  .btn {
    width: 100%;
    text-align: center;
  }
  .container_banner {
    display: flex;
    flex-direction: column;
    height: min-content;
    max-height: unset;
  }
  .banner_text_content {
    text-align: center;
  }
  .banner_img {
    max-height: 250px;
    object-position: center 40%;
  }
  .hero_slider_container {
    max-height: 85vh;
  }

  .slider_info_content {
    top: unset;
    left: 0;
    bottom: 0;
    padding: 25px;
    height: min-content;
    max-width: 400px;
    gap: 20px;
  }
  .slider_info_content h2 {
    font-size: 40px !important;
    font-weight: 300 !important;
  }
  .slider_info_controls {
    gap: 20px;
  }
  .slider_info_controls .platform_grid {
    width: 100%;
  }
  .platform_grid_item div {
    height: 100%;
    max-height: 300px;
  }
  .platform_grid_item div img {
    object-fit: cover;
    width: 100%;
    height: 125%;
    max-height: 300px;
    transition: all 200ms ease;
  }
  .clients_grid_item {
    align-items: center;
  }
  .clients_grid_item div {
    min-width: 350px;
    padding: 25px;
    max-height: 280px;
    margin: auto;
  }
  .clients_grid_item div h1 {
    font-size: 40px !important;
    text-align: center;
    font-weight: 300 !important;
  }
  .clients_grid_item::before {
    background: linear-gradient(to top, #000000ee 90px, #00000044 900px);
  }
  .clients_grid_item div a {
    width: unset;
  }
  .container_vibe {
    height: 100%;
    height: unset;
  }
  .content_vibe {
    max-height: unset;
    gap: 50px;
  }

  .vibe_img_content {
    height: 100%;
    max-height: unset;
  }

  .post_content {
    flex-direction: column;
    text-align: center;
    gap: 50px;
  }
  .post,
  .post_alt {
    margin: unset !important;
    padding: 0 25px;
  }
  .post_img {
    order: -1 !important;
    max-width: 90vw;
  }
  .contact_container {
    padding: 50px 25px;
  }
  .contact_container img {
    height: 40px;
    width: 40px;
  }
  .footer_grid {
  }
}
@media (max-width: 1270px) {
  html,
  body {
    min-width: 100% !important;
    overflow-x: hidden;
  }

  .platform_grid {
    grid-template-rows: unset;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .platform_grid_top {
    grid-template-columns: 1fr;
  }
  .platform_grid_bottom {
    grid-template-columns: 1fr;
  }
}
