@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:wght@600;700;800&display=swap');

:root{
  --font-heading:'Playfair Display', serif;
  --font-body:'Inter', sans-serif;
  --bg:#f7f5f1;
  --surface:#fffdf8;
  --surface-soft:#efe9de;
  --text:#1f2622;
  --muted:#66706b;
  --green:#2f6b57;
  --green-dark:#16382f;
  --green-soft:#e7f0ec;
  --gold:#c9a56d;
  --border:rgba(31, 38, 34, 0.12);
  --shadow:0 18px 45px rgba(22, 56, 47, 0.10);
}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
}

.browse-page{
  background:
    radial-gradient(circle at top center, rgba(233, 223, 206, 0.54), transparent 22%),
    linear-gradient(180deg, #f7f5f1 0%, #fbf9f5 100%);
}

.browse-motion-ready [data-browse-animate]{
  opacity:0;
  transform:translate3d(0, 34px, 0);
  filter:blur(8px);
  transition:
    opacity .7s cubic-bezier(.22, 1, .36, 1),
    transform .7s cubic-bezier(.22, 1, .36, 1),
    filter .7s cubic-bezier(.22, 1, .36, 1);
  transition-delay:var(--browse-reveal-delay, 0ms);
}

.browse-motion-ready [data-browse-animate="hero"]{
  transform:translate3d(0, 24px, 0);
}

.browse-motion-ready [data-browse-animate].is-visible{
  opacity:1;
  transform:translate3d(0, 0, 0);
  filter:blur(0);
}

@media (prefers-reduced-motion: reduce){
  .browse-motion-ready [data-browse-animate],
  .browse-motion-ready [data-browse-animate].is-visible{
    opacity:1;
    transform:none;
    filter:none;
    transition:none;
  }
}

.browse-section-kicker{
  display:inline-block;
  margin-bottom:10px;
  color:var(--green);
  font-family:var(--font-body);
  font-size:.7rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.browse-hero{
  position:relative;
  min-height:390px;
  overflow:hidden;
  background:#172b23;
}

.browse-hero__image,
.browse-hero__overlay{
  position:absolute;
  inset:0;
}

.browse-hero__image{
  background:
    linear-gradient(180deg, rgba(15, 31, 26, 0.08), rgba(15, 31, 26, 0.12)),
    url("../images/marketing/coastal-holiday-park-aerial.jpg") center/cover no-repeat;
  transform:translate3d(0, var(--browse-hero-shift, 0px), 0) scale(1.04);
  transition:transform .18s linear;
}

.browse-hero__overlay{
  background:
    linear-gradient(90deg, rgba(9, 24, 20, 0.84) 0%, rgba(9, 24, 20, 0.54) 44%, rgba(9, 24, 20, 0.16) 100%),
    linear-gradient(180deg, rgba(9, 24, 20, 0.2) 0%, rgba(9, 24, 20, 0.5) 100%);
}

.browse-hero__inner{
  position:relative;
  z-index:1;
  padding-top:126px;
  padding-bottom:72px;
}

.browse-hero__content{
  max-width:680px;
}

.browse-hero__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.10);
  color:#f4efe7;
  font-family:var(--font-body);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.browse-hero h1{
  margin:16px 0 12px;
  color:#fff8ef;
  font-family:var(--font-heading);
  font-size:clamp(2.3rem, 4.4vw, 3.9rem);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.04em;
  max-width:560px;
}

.browse-hero h1 span{
  color:#7ed1aa;
}

.browse-hero p{
  max-width:500px;
  margin:0 0 18px;
  color:rgba(255,255,255,0.82);
  font-family:var(--font-body);
  font-size:.9rem;
  line-height:1.62;
}

.browse-hero__pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.browse-hero__pills span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  background:rgba(255,255,255,0.12);
  color:#f6fbf7;
  font-size:.72rem;
  font-weight:700;
}

.browse-filters-wrap{
  position:relative;
  z-index:2;
  margin-top:-48px;
}

.browse-filters-card{
  padding:20px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,0.72);
  background:rgba(255,253,248,0.94);
  box-shadow:0 26px 54px rgba(20, 37, 29, 0.12);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.browse-filters-card__head{
  margin-bottom:14px;
}

.browse-filters-card__head h2{
  margin:0 0 5px;
  color:var(--text);
  font-family:var(--font-heading);
  font-size:clamp(1.55rem, 2.4vw, 2.15rem);
  font-weight:700;
  line-height:1.06;
  letter-spacing:-.03em;
}

.browse-filters-card__head p{
  max-width:760px;
  margin:0;
  color:var(--muted);
  font-family:var(--font-body);
  font-size:.88rem;
  line-height:1.62;
}

.browse-filters-grid{
  display:grid;
  grid-template-columns:1.4fr repeat(3, minmax(0, .9fr));
  gap:12px;
  align-items:end;
}

.browse-filter-field{
  display:grid;
  gap:6px;
}

.browse-filter-field label{
  color:#314039;
  font-family:var(--font-body);
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.browse-input{
  min-height:48px;
  border-radius:12px;
  border:1px solid rgba(31, 38, 34, 0.10);
  background:#fff;
  color:var(--text);
  font-family:var(--font-body);
  font-size:.84rem;
  box-shadow:none !important;
  padding-inline:14px;
}

.browse-input:focus,
.browse-sort-select:focus{
  border-color:rgba(47, 107, 87, 0.45);
  box-shadow:0 0 0 .22rem rgba(47, 107, 87, 0.10) !important;
}

.browse-filter-actions{
  display:flex;
  gap:10px;
  grid-column:1 / -1;
  padding-top:2px;
}

.browse-search-btn,
.browse-clear-btn,
.browse-card-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 18px;
  border-radius:12px;
  font-family:var(--font-body);
  font-size:.84rem;
  font-weight:700;
  text-decoration:none;
  transition:transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease, color .2s ease;
}

.browse-search-btn{
  border:none;
  background:linear-gradient(180deg, var(--green), var(--green-dark));
  color:#fff;
  box-shadow:0 16px 28px rgba(22, 56, 47, 0.16);
}

.browse-search-btn:hover{
  color:#fff;
  transform:translateY(-1px);
}

.browse-clear-btn{
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
}

.browse-clear-btn:hover{
  color:var(--text);
  border-color:rgba(47, 107, 87, 0.28);
  background:#faf8f3;
  transform:translateY(-1px);
}

.browse-results-head{
  padding:34px 0 18px;
}

.results-bar{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  padding:0 0 16px;
  border-bottom:1px solid rgba(31, 38, 34, 0.08);
}

.results-title{
  margin:0 0 5px;
  color:var(--text);
  font-family:var(--font-heading);
  font-size:clamp(1.7rem, 2.4vw, 2.4rem);
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.03em;
}

.results-sub{
  margin:0;
  color:var(--muted);
  font-family:var(--font-body);
  font-size:.86rem;
  line-height:1.58;
}

.results-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}

.results-tags span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 11px;
  border-radius:999px;
  background:var(--green-soft);
  color:var(--green-dark);
  font-size:.72rem;
  font-weight:700;
}

.results-sort{
  display:flex;
  align-items:center;
  gap:10px;
}

.results-sort-label{
  margin:0;
  color:var(--muted);
  font-family:var(--font-body);
  font-size:.8rem;
  font-weight:700;
}

.browse-sort-select{
  min-width:220px;
  min-height:44px;
  border-radius:12px;
  border:1px solid rgba(31, 38, 34, 0.10);
  background:#fffdf8;
  box-shadow:none !important;
  font-family:var(--font-body);
  font-size:.84rem;
}

.browse-listings-section{
  padding:10px 0 60px;
}

.browse-card{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  background:var(--surface);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  height:100%;
  transition:transform .28s ease, box-shadow .28s ease;
}

.browse-card:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 48px rgba(22, 56, 47, 0.12);
}

.browse-card-image-wrap{
  position:relative;
  display:block;
  aspect-ratio:1 / .8;
  overflow:hidden;
  background:#e9e1d5;
}

.browse-card-image-wrap--carousel{
  isolation:isolate;
}

.browse-card-track{
  display:flex;
  width:100%;
  height:100%;
  transition:transform .35s ease;
  will-change:transform;
}

.browse-card-slide{
  position:relative;
  flex:0 0 100%;
  width:100%;
  height:100%;
  display:block;
}

.browse-card-image{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .42s ease;
}

.browse-card:hover .browse-card-image{
  transform:scale(1.04);
}

.browse-card-image-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(11, 24, 20, 0.04), rgba(11, 24, 20, 0.36));
}

.browse-card-badge{
  position:absolute;
  top:12px;
  left:12px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  min-height:27px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(255,255,255,0.94);
  color:var(--green-dark);
  font-size:.67rem;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.browse-card-video-link{
  position:absolute;
  top:12px;
  right:12px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(15, 31, 26, 0.76);
  border:1px solid rgba(255,255,255,0.18);
  color:#fff;
  text-decoration:none;
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.04em;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.browse-card-video-link:hover{
  color:#fff;
  background:rgba(15, 31, 26, 0.88);
}

.browse-card-video-link__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:50%;
  background:rgba(255,255,255,0.16);
  font-size:.6rem;
}

.browse-card-nav{
  position:absolute;
  top:50%;
  z-index:3;
  width:38px;
  height:38px;
  border:none;
  border-radius:50%;
  transform:translateY(-50%);
  background:rgba(15, 31, 26, 0.72);
  color:#fff;
  font-size:1.2rem;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 22px rgba(11, 24, 20, 0.18);
  transition:background .2s ease;
}

.browse-card-nav:hover{
  background:rgba(15, 31, 26, 0.9);
}

.browse-card-nav--prev{
  left:12px;
}

.browse-card-nav--next{
  right:12px;
}

.browse-card-dots{
  position:absolute;
  left:50%;
  bottom:14px;
  z-index:3;
  display:flex;
  align-items:center;
  gap:7px;
  transform:translateX(-50%);
}

.browse-card-dot{
  width:8px;
  height:8px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,0.48);
  padding:0;
  transition:transform .2s ease, background .2s ease;
}

.browse-card-dot.is-active{
  transform:scale(1.15);
  background:#fff;
}

.browse-card-media-count{
  position:absolute;
  left:14px;
  bottom:12px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(15, 31, 26, 0.68);
  color:#fff;
  font-size:.7rem;
  font-weight:700;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.browse-card-placeholder{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:#9b8d7c;
}

.browse-card-placeholder-icon{
  width:42px;
  height:38px;
  opacity:.55;
}

.browse-card-placeholder span{
  font-size:.76rem;
  font-weight:600;
}

.browse-card-body{
  display:flex;
  flex-direction:column;
  flex:1;
  padding:15px 15px 16px;
}

.browse-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}

.browse-card-location{
  display:flex;
  align-items:center;
  gap:6px;
  margin:0;
  color:#8b7550;
  font-size:.74rem;
  font-weight:700;
}

.browse-loc-dot{
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--gold);
  flex-shrink:0;
}

.browse-card-price{
  color:var(--green);
  font-size:1.14rem;
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1;
  white-space:nowrap;
}

.browse-card-title{
  margin:0 0 10px;
  color:var(--text);
  font-family:var(--font-heading);
  font-size:1.06rem;
  font-weight:700;
  line-height:1.16;
  letter-spacing:-.03em;
}

.browse-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin:0 0 12px;
}

.browse-card-meta span{
  display:inline-flex;
  align-items:center;
  min-height:27px;
  padding:0 10px;
  border-radius:999px;
  background:#f3f1eb;
  color:#4e5753;
  font-size:.7rem;
  font-weight:700;
}

.browse-card-meta .seller-type{
  background:var(--green-soft);
  color:var(--green-dark) !important;
}

.browse-card-desc{
  margin:0 0 14px;
  color:var(--muted);
  font-family:var(--font-body);
  font-size:.84rem;
  line-height:1.58;
  flex-grow:1;
}

.browse-card-footer{
  margin-top:auto;
}

.browse-card-btn{
  width:100%;
  border:none;
  background:#f4efe7;
  color:var(--text);
}

.browse-card-btn:hover{
  color:var(--text);
  background:#ebe4d8;
  transform:translateY(-1px);
}

.browse-empty-state{
  padding:50px 22px;
  border-radius:24px;
  border:1px dashed rgba(31, 38, 34, 0.16);
  background:var(--surface);
  text-align:center;
}

.browse-empty-icon{
  width:46px;
  height:40px;
  opacity:.35;
  margin:0 auto 16px;
  display:block;
}

.browse-empty-state h3{
  margin:0 0 8px;
  color:var(--text);
  font-family:var(--font-heading);
  font-size:1.3rem;
}

.browse-empty-state p{
  max-width:560px;
  margin:0 auto 18px;
  color:var(--muted);
  font-size:.86rem;
  line-height:1.62;
}

.browse-empty-btn{
  min-width:180px;
}

@media (max-width: 1199.98px){
  .browse-filters-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .browse-filter-field--wide{
    grid-column:1 / -1;
  }
}

@media (max-width: 991.98px){
  .browse-hero{
    min-height:340px;
  }

  .browse-hero__inner{
    padding-top:112px;
    padding-bottom:62px;
  }

  .results-sort{
    width:100%;
    justify-content:flex-start;
  }

  .browse-sort-select{
    min-width:unset;
    width:100%;
  }
}

@media (max-width: 767.98px){
  .browse-hero{
    min-height:300px;
  }

  .browse-hero__inner{
    padding-top:78px;
    padding-bottom:34px;
  }

  .browse-hero__content{
    padding-inline:10px 12px;
  }

  .browse-hero h1{
    font-size:2.05rem;
  }

  .browse-hero p{
    font-size:.86rem;
  }

  .browse-filters-wrap{
    margin-top:-30px;
  }

  .browse-filters-card{
    padding:16px;
    border-radius:20px;
  }

  .browse-filters-grid{
    grid-template-columns:1fr;
  }

  .browse-filter-field--wide{
    grid-column:auto;
  }

  .browse-filter-actions{
    flex-direction:column;
  }

  .browse-search-btn,
  .browse-clear-btn{
    width:100%;
  }

  .browse-results-head{
    padding:28px 0 14px;
  }

  .results-title{
    font-size:1.8rem;
  }

  .browse-listings-section{
    padding-bottom:42px;
  }

  .browse-card-nav{
    width:34px;
    height:34px;
  }

  .browse-card-media-count{
    font-size:.66rem;
  }
}
