
:root{
  --bg-0:#0b0b0b; --bg-1:#1a1a1a; --bg-2:#2b2b2b;
  --text-0:#f2f2f2; --text-1:#cfcfcf; --border-0:#3a3a3a;
}
html,body{min-height:100%}
body{
  background: linear-gradient(180deg, var(--bg-0), var(--bg-1) 50%, var(--bg-2)) fixed;
  color: var(--text-0);
}
a{color:#9ecbff}
.card,.section,.container,.content,.panel,.box,header,footer,nav,.navbar,.menu,.sidebar,.widget,.gallery,.lead-capture,.form-card{
  background: rgba(20,20,20,.55);
  border-color: var(--border-0) !important;
  box-shadow: 0 6px 24px rgba(0,0,0,.35);
}
input,textarea,select{background:#151515 !important;color:var(--text-0) !important;border:1px solid var(--border-0) !important}
/* Modal robust layout */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;padding:16px;z-index:1000}
.modal.open{display:flex !important}
.modal-card{background:#111;color:#fff;border-radius:16px;width:min(100%,920px);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-media{flex:0 0 auto}
.modal-media img{width:100%;height:auto;max-height:50vh;object-fit:cover;display:block;border-bottom:1px solid #222}
.modal-body{flex:1 1 auto;overflow:auto;padding:16px 18px 96px}
.modal-actions{position:sticky;bottom:0;background:linear-gradient(180deg, rgba(18,18,18,.65), rgba(18,18,18,.95));backdrop-filter:blur(6px);padding:12px 16px;border-top:1px solid var(--border-0);display:flex;gap:12px;flex-wrap:wrap;z-index:5}


/* === Listings Full-Width Layout (override) === */
section.listings { padding-left: 24px; padding-right: 24px; }
section.listings .container {
  max-width: 1400px !important;  /* widen the content */
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
/* Make grid fill the available row width */
section.listings .cards{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 20px !important;
}
/* Ensure cards stretch nicely */
section.listings .card, section.listings .listing-card{
  width: 100% !important;
}
/* Optional: on huge screens, expand to near full-bleed */
@media (min-width: 1440px){
  section.listings .container{ max-width: 1600px !important; }
}



/* ===== Mobile enhancements ===== */
@media (max-width: 768px){
  /* Global spacing */
  .container{ padding-left: 16px !important; padding-right: 16px !important; }

  /* Headings and text slightly smaller for fit */
  h1{ font-size: 1.6rem; }
  h2{ font-size: 1.3rem; }
  h3{ font-size: 1.15rem; }

  /* Listings grid packs tighter */
  section.listings .cards{
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    gap: 14px !important;
  }

  /* About section: stack text above images */
  .about .row, .about .container{ display: block !important; }
  .about-gallery{ display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; }
  .about-gallery img{ width: 100%; height: auto; display: block; }

  /* Footer & sections tighter */
  section{ padding-top: 24px; padding-bottom: 24px; }
}

/* ===== Mobile menu (hamburger dropdown) ===== */
.mobile-nav-toggle{
  display: none;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--border-0);
  border-radius: 8px;
  background: rgba(25,25,25,.6);
  color: var(--text-0);
  cursor: pointer;
}
@media (max-width: 900px){
  .site-header .nav{ display: none !important; }         /* hide desktop nav */
  .mobile-nav-toggle{ display: inline-flex; }            /* show hamburger */
}
/* dropdown panel */
#mobileMenu{
  position: fixed; top: 60px; right: 12px;
  width: min(92vw, 340px);
  background: rgba(20,20,20,.95);
  border: 1px solid var(--border-0);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(0,0,0,.5);
  padding: 10px;
  display: none;
  z-index: 1200;
}
#mobileMenu.open{ display: block; }
#mobileMenu a{
  display: block;
  padding: 10px 12px;
  color: var(--text-0);
  text-decoration: none;
  border-radius: 8px;
}
#mobileMenu a:hover{ background: rgba(255,255,255,.06); }
#mobileMenu hr{ border: none; border-top: 1px solid var(--border-0); margin: 8px 0; }


/* === Stronger full-width overrides for Featured Listings === */
section.listings .container{
  max-width: 1600px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}
/* The inner grid also uses class "listings" — make it full-width grid */
section.listings .listings{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
  gap: 22px !important;
  width: 100% !important;
}
section.listings .listing-card,
section.listings .card{
  width: 100% !important;
}



/* === Listings Edge-to-Edge & 1800px Wide Layout === */
section.listings {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
section.listings .container{
  max-width: 1800px !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
section.listings .listings{
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
  gap: 24px !important;
  width: 100% !important;
  margin: 0 auto !important;
}
section.listings .card, section.listings .listing-card{
  width: 100% !important;
}



/* === Reference-style Listings Grid (like the screenshot) === */
section.listings{
  padding-left: clamp(16px, 4vw, 40px) !important;
  padding-right: clamp(16px, 4vw, 40px) !important;
}
section.listings .container{
  max-width: 1400px !important;   /* centered content like the ref */
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 !important;
}
/* Inner grid - 1/2/3/4 columns with generous gaps */
section.listings .listings{
  display: grid !important;
  gap: clamp(16px, 2.5vw, 28px) !important;
  grid-template-columns: repeat(1, minmax(260px, 1fr)) !important;
}
@media (min-width: 640px){
  section.listings .listings{ grid-template-columns: repeat(2, minmax(260px, 1fr)) !important; }
}
@media (min-width: 992px){
  section.listings .listings{ grid-template-columns: repeat(3, minmax(260px, 1fr)) !important; }
}
@media (min-width: 1280px){
  section.listings .listings{ grid-template-columns: repeat(4, minmax(260px, 1fr)) !important; }
}
section.listings .listing-card, section.listings .card{
  width: 100% !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 26px rgba(0,0,0,0.35);
}
/* Image area: match ref feel (wide 16:9) */
section.listings .listing-card .media{
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #0f0f10;
}
section.listings .listing-card .media img{
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
/* Slight hover lift like product cards */
@media (hover:hover){
  section.listings .listing-card{ transition: transform .18s ease, box-shadow .18s ease; }
  section.listings .listing-card:hover{
    transform: translateY(-3px);
    box-shadow: 0 16px 32px rgba(0,0,0,0.45);
  }
}



/* === Listings FULL‑BLEED (edge to edge across the screen) === */
section.listings{
  /* pull the section out of any centered page wrapper */
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  width: 100vw !important;
  padding-left: clamp(12px, 3vw, 36px) !important;
  padding-right: clamp(12px, 3vw, 36px) !important;
  box-shadow: none !important; /* remove any panel shadow that visually "stops" it */
}
section.listings .container{
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
section.listings .listings{
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
  gap: clamp(16px, 2.2vw, 28px) !important;
  width: 100% !important;
}
/* ensure cards expand nicely */
section.listings .listing-card, section.listings .card{ width: 100% !important; }



/* === WIDTH-ONLY FIX for Featured Listings === */
/* Use the page width, keep normal section height */
section.listings{
  margin-left: 0 !important;
  margin-right: 0 !important;
  width: 100% !important;
  padding-left: clamp(16px, 3vw, 40px) !important;
  padding-right: clamp(16px, 3vw, 40px) !important;
}
/* Let the container span the full page width (no max cap) */
section.listings .container{
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
}
/* Increase number of columns on larger screens */
section.listings .listings{
  width: 100% !important;
  display: grid !important;
  gap: clamp(16px, 2vw, 24px) !important;
  grid-template-columns: repeat(1, minmax(260px, 1fr)) !important;
}
@media (min-width: 640px){
  section.listings .listings{ grid-template-columns: repeat(2, minmax(260px, 1fr)) !important; }
}
@media (min-width: 900px){
  section.listings .listings{ grid-template-columns: repeat(3, minmax(260px, 1fr)) !important; }
}
@media (min-width: 1200px){
  section.listings .listings{ grid-template-columns: repeat(4, minmax(260px, 1fr)) !important; }
}
@media (min-width: 1440px){
  section.listings .listings{ grid-template-columns: repeat(5, minmax(260px, 1fr)) !important; }
}
@media (min-width: 1680px){
  section.listings .listings{ grid-template-columns: repeat(6, minmax(260px, 1fr)) !important; }
}
section.listings .listing-card, section.listings .card{ width: 100% !important; }

