/* ===== PROPERTIES PAGE SPECIFIC STYLES ===== */

/* PAGE HERO */
.page-hero{
  padding:10rem 3rem 4rem;
  position:relative;
  background:
    radial-gradient(ellipse at top right,rgba(201,169,97,0.08) 0%,transparent 50%),
    radial-gradient(ellipse at bottom left,rgba(10,61,58,0.06) 0%,transparent 55%),
    var(--paper);
  overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(90deg,transparent 0,transparent 119px,rgba(10,61,58,0.025) 119px,rgba(10,61,58,0.025) 120px),
    repeating-linear-gradient(0deg,transparent 0,transparent 119px,rgba(10,61,58,0.025) 119px,rgba(10,61,58,0.025) 120px);
  pointer-events:none;
}
.page-hero-watermark{
  position:absolute;right:-8%;bottom:-25%;
  font-family:var(--serif);font-weight:900;font-style:italic;
  font-size:clamp(20rem,45vw,50rem);line-height:.8;
  color:var(--emerald-ink);opacity:.035;pointer-events:none;user-select:none;
}
.page-hero-inner{max-width:1400px;margin:0 auto;position:relative;z-index:2}
.page-hero-breadcrumb{
  display:flex;align-items:center;gap:.6rem;
  font-size:.78rem;font-weight:500;color:var(--emerald-mid);
  margin-bottom:2rem;
  opacity:0;transform:translateY(20px);animation:revealUp .8s .2s var(--ease-apple) forwards;
}
.page-hero-breadcrumb a{color:var(--emerald-mid);text-decoration:none;transition:color .3s}
.page-hero-breadcrumb a:hover{color:var(--gold-deep)}
.page-hero-breadcrumb span{color:rgba(10,61,58,.4)}
.page-hero-title{
  font-family:var(--serif);font-size:clamp(2.5rem,6vw,5rem);
  font-weight:400;line-height:1;letter-spacing:-.02em;
  color:var(--emerald-ink);margin-bottom:1rem;
  opacity:0;transform:translateY(30px);animation:revealUp .9s .35s var(--ease-apple) forwards;
}
.page-hero-title em{font-family:var(--serif-alt);font-style:italic;color:var(--gold-deep)}
.page-hero-sub{
  font-size:1.05rem;color:rgba(10,10,8,.65);max-width:52ch;line-height:1.65;
  opacity:0;transform:translateY(20px);animation:revealUp .9s .55s var(--ease-apple) forwards;
}
.page-hero-count{
  font-family:var(--serif);color:var(--gold-deep);font-weight:500;
}

/* FILTER BAR */
.filter-bar{
  background:var(--paper);
  border-top:1px solid rgba(10,61,58,.08);
  border-bottom:1px solid rgba(10,61,58,.08);
  padding:1.25rem 3rem;
  position:sticky;top:62px;z-index:50;
  transition:box-shadow .4s var(--ease-apple);
}
.filter-bar.shadow{box-shadow:0 8px 30px -10px rgba(10,61,58,.15)}
.filter-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:.3rem;position:relative}
.filter-label{font-size:.62rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep)}
.filter-select{
  background:transparent;border:1px solid rgba(10,61,58,.15);
  padding:.55rem 2rem .55rem .75rem;font-family:var(--sans);font-size:.82rem;
  color:var(--emerald-ink);cursor:pointer;min-width:140px;
  border-radius:0;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%238c7038' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .6rem center;
  transition:border-color .3s,background .3s;
}
.filter-select:focus{border-color:var(--gold);outline:none;background-color:var(--sand-warm)}
.filter-select option{background:var(--paper);color:var(--emerald-ink)}
.filter-divider{width:1px;height:36px;background:rgba(10,61,58,.12);margin:0 .5rem;align-self:flex-end}
.filter-sort{margin-left:auto}
.filter-clear{
  padding:.5rem 1rem;background:transparent;
  border:1px solid rgba(196,101,74,.3);color:var(--coral-accent);
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
  transition:all .3s var(--ease-apple);align-self:flex-end;
}
.filter-clear:hover{background:var(--coral-accent);color:var(--paper);border-color:var(--coral-accent)}
.filter-count{
  font-size:.78rem;color:var(--emerald-mid);align-self:flex-end;
  padding:.55rem 0;font-weight:500;white-space:nowrap;
}
.filter-count strong{color:var(--emerald-ink);font-family:var(--serif);font-size:1.1rem}

/* ACTIVE FILTERS CHIPS */
.active-filters{
  max-width:1400px;margin:0 auto;padding:.75rem 3rem 0;
  display:flex;gap:.5rem;flex-wrap:wrap;
}
.active-filter-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .7rem;background:var(--sand-warm);
  font-size:.72rem;font-weight:500;color:var(--emerald-ink);
  border:1px solid rgba(10,61,58,.1);cursor:pointer;
  transition:all .3s var(--ease-apple);
}
.active-filter-chip:hover{background:var(--coral-accent);color:var(--paper);border-color:var(--coral-accent)}
.active-filter-chip svg{width:12px;height:12px}

/* PROPERTIES GRID */
.props-section{padding:3rem 3rem 6rem}
.props-inner{max-width:1400px;margin:0 auto}
.props-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.prop-card{
  background:var(--paper);overflow:hidden;cursor:none;
  transition:transform .6s var(--ease-apple),box-shadow .6s var(--ease-apple),opacity .5s;
  position:relative;border:1px solid rgba(10,61,58,.08);
  opacity:1;
}
.prop-card.hidden{display:none}
.prop-card:hover{transform:translateY(-8px);box-shadow:0 40px 70px -24px rgba(10,61,58,.32)}
.prop-img{position:relative;overflow:hidden;background:var(--emerald-deep);height:300px}
.prop-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease-apple),filter 1s var(--ease-apple)}
.prop-card:hover .prop-img img{transform:scale(1.08);filter:brightness(1.05)}
.prop-badge{
  position:absolute;top:1.25rem;left:1.25rem;color:var(--emerald-ink);
  padding:.4rem .8rem;font-size:.65rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  display:flex;align-items:center;gap:.5rem;
  backdrop-filter:blur(10px);background:rgba(250,247,238,.92);
}
.prop-badge-x{font-family:var(--serif);font-weight:900;font-style:italic;color:var(--gold-deep)}
.prop-badge.exclusive{background:var(--emerald-ink);color:var(--gold-bright)}
.prop-badge.new{background:var(--coral-accent);color:var(--paper)}
.prop-save{
  position:absolute;top:1.25rem;right:1.25rem;width:40px;height:40px;
  background:rgba(250,247,238,.92);backdrop-filter:blur(10px);
  border:none;border-radius:50%;display:grid;place-items:center;
  cursor:none;color:var(--emerald-ink);
  opacity:0;transform:translateY(-10px);transition:all .4s var(--ease-apple);
}
.prop-card:hover .prop-save{opacity:1;transform:translateY(0)}
.prop-save:hover{background:var(--gold);color:var(--paper);transform:scale(1.1)}
.prop-save.saved{background:var(--coral-accent);color:var(--paper);opacity:1;transform:translateY(0)}
.prop-save.saved svg{fill:currentColor}
.prop-info{padding:1.75rem 1.5rem 1.5rem;background:var(--paper)}
.prop-location{font-size:.7rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.6rem;display:flex;align-items:center;gap:.5rem}
.prop-title{font-family:var(--serif);font-size:1.35rem;font-weight:500;line-height:1.15;color:var(--emerald-ink);margin-bottom:.9rem;letter-spacing:-.005em}
.prop-meta{display:flex;gap:1.5rem;padding:.9rem 0;border-top:1px solid rgba(10,61,58,.08);border-bottom:1px solid rgba(10,61,58,.08);margin-bottom:1rem}
.prop-meta-item{display:flex;flex-direction:column;font-size:.75rem}
.prop-meta-item span{color:rgba(10,61,58,.55);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}
.prop-meta-item strong{color:var(--emerald-ink);font-weight:600;font-family:var(--serif-alt);font-size:1.1rem;margin-top:2px}
.prop-price{display:flex;justify-content:space-between;align-items:flex-end}
.prop-price-val{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--emerald-ink);letter-spacing:-.01em}
.prop-price-val small{font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.1em;color:var(--gold-deep);margin-left:.25rem}
.prop-view{font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--emerald-ink);display:flex;align-items:center;gap:.4rem;transition:all .4s var(--ease-apple);text-decoration:none}
.prop-card:hover .prop-view{color:var(--gold-deep);gap:.7rem}

/* LOAD MORE */
.load-more-wrap{text-align:center;margin-top:3rem}
.load-more{
  padding:1rem 3rem;background:transparent;
  border:1.5px solid var(--emerald-ink);color:var(--emerald-ink);
  font-family:var(--sans);font-size:.8rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;cursor:pointer;
  transition:all .4s var(--ease-apple);position:relative;overflow:hidden;
}
.load-more::before{content:'';position:absolute;inset:0;background:var(--emerald-ink);transform:translateY(100%);transition:transform .4s var(--ease-apple)}
.load-more:hover::before{transform:translateY(0)}
.load-more:hover{color:var(--sand)}
.load-more span{position:relative;z-index:2}

/* NO RESULTS */
.no-results{
  text-align:center;padding:5rem 2rem;display:none;
}
.no-results.show{display:block}
.no-results-x{
  font-family:var(--serif);font-weight:900;font-style:italic;
  font-size:5rem;color:var(--emerald-ink);opacity:.1;
  display:block;margin-bottom:1.5rem;
}
.no-results h3{font-family:var(--serif);font-size:1.8rem;color:var(--emerald-ink);font-weight:500;margin-bottom:.75rem}
.no-results p{font-size:.95rem;color:rgba(10,10,8,.6);max-width:40ch;margin:0 auto;line-height:1.65}

/* RESPONSIVE */
@media(max-width:1024px){
  .page-hero{padding:8rem 1.5rem 3rem}
  .props-grid{grid-template-columns:repeat(2,1fr)}
  .filter-bar{padding:1rem 1.5rem;top:56px}
  .filter-inner{gap:.75rem}
  .filter-divider{display:none}
  .filter-select{min-width:120px;font-size:.78rem}
  .props-section{padding:2rem 1.5rem 4rem}
  .active-filters{padding:.75rem 1.5rem 0}
}
@media(max-width:600px){
  .props-grid{grid-template-columns:1fr}
  .filter-inner{flex-direction:column;align-items:stretch}
  .filter-group{width:100%}
  .filter-select{width:100%}
  .filter-sort{margin-left:0}
  .filter-count{text-align:center}
  .page-hero-title{font-size:2.4rem}
}
