@import url("https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap");

:root{
  --catalog-ease-out:cubic-bezier(0.16,1,0.3,1);
  --catalog-ease-in:cubic-bezier(0.76,0,0.24,1);
  --catalog-skeleton-bg:linear-gradient(90deg,rgba(238,238,238,0.85) 0%,rgba(248,248,248,0.65) 40%,rgba(238,238,238,0.85) 100%);
  --catalog-card-surface:linear-gradient(180deg,#ffffff 0%,#fff9f9 100%);
  --catalog-card-border:rgba(17,17,17,0.06);
  --catalog-card-shadow:0 22px 44px rgba(17,17,17,0.18);
  --catalog-amber-soft:#f3af3d;
  --catalog-amber-strong:#f18a2f;
  --catalog-amber-focus:rgba(243,175,61,0.28);
  --catalog-amber-gradient-main:linear-gradient(135deg,#f3af3d 0%,#fbd269 100%);
  --catalog-amber-gradient-soft:linear-gradient(135deg,rgba(243,175,61,0.18) 0%,rgba(243,175,61,0.32) 100%);
  --catalog-amber-gradient-header:linear-gradient(135deg,rgba(241,138,47,1) 0%,rgba(243,175,61,1) 55%,rgba(248,210,125,1) 100%);
  --catalog-button-bg:#f3b04d;
  --catalog-button-bg-hover:#d0741c;
  --catalog-button-text:#ffffff;
}

@keyframes shimmer{
  0%{background-position:-200% 0;}
  100%{background-position:200% 0;}
}

@keyframes catalogViewIn{
  0%{opacity:0;transform:translateY(12px) scale(0.98);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}

@keyframes catalogViewOut{
  0%{opacity:1;transform:translateY(0) scale(1);}
  100%{opacity:0;transform:translateY(-12px) scale(0.96);}
}

@keyframes favPulse{
  0%{transform:scale(1);}
  30%{transform:scale(1.12);}
  55%{transform:scale(0.95);}
  100%{transform:scale(1);}
}

@keyframes favButtonPop{
  0%{transform:scale(1);}
  45%{transform:scale(1.18);}
  100%{transform:scale(1);}
}

#catalog-wrapper{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  margin:0 auto;
  padding:clamp(1rem,4vw,2.75rem) clamp(1.25rem,6vw,4rem);
  gap:clamp(1.25rem,4vw,3rem);
  max-width:1360px;
  box-sizing:border-box;
  font-family:'Nunito',sans-serif;
}
@media (max-width:1023px){
  #catalog-wrapper{
    flex-direction:column;
    padding:clamp(1rem,4vw,2rem) clamp(.75rem,5vw,1.5rem);
    gap:clamp(1rem,5vw,2rem);
  }
}

#catalog-main{
  flex:1;
  display:flex;
  flex-direction:column;
  position:relative;
  width:100%;
  min-width:0;
  gap:clamp(1rem,3vw,2rem);
}

#catalog-filters{
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  width:min(320px,100%);
  margin:0;
  padding:1.5rem 1.75rem;
  overflow:hidden;
  position:relative;
  box-sizing:border-box;
  border-radius:28px;
  background:linear-gradient(140deg,rgba(255,255,255,0.92) 0%,rgba(255,248,237,0.9) 45%,rgba(255,255,255,0.85) 100%);
  border:1px solid rgba(17,17,17,0.05);
  box-shadow:0 24px 48px rgba(17,17,17,0.12);
  /* Removed backdrop blur to keep filter panel background crisp without grey haze */
  backdrop-filter:none;
  isolation:isolate;
}
#catalog-filters::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(120% 120% at 12% 8%,rgba(243,175,61,0.18) 0%,rgba(243,175,61,0.06) 65%,rgba(255,255,255,0) 100%);
  z-index:-1;
  pointer-events:none;
  opacity:0.9;
}

#filters-close{display:none;}

#catalog-filters h4{
  margin:0;
  font-size:1.05rem;
  font-weight:700;
  letter-spacing:.01em;
  color:#1f2a44;
}

#catalog-filters label{
  font-size:.92rem;
  color:#3c4663;
}

#catalog-filters input,
#catalog-filters select{
  font-size:.95rem;
}

.filter-actions {
  display: flex;
  gap: .5rem;
}

.filter-actions button {
  flex: 1;
  padding: .85rem;
}

body.filters-open{overflow:hidden;touch-action:none;}

#catalog-filters-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(4px);
  opacity:0;
  pointer-events:none;
  transition:opacity .32s ease;
  z-index:1400;
}

#catalog-filters-overlay.visible{
  opacity:1;
  pointer-events:auto;
}

#catalog-filters .filter-content{
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  flex:1;
  overflow-y:auto;
  padding-right:.35rem;
}
#catalog-filters .filter-content{scrollbar-width:thin;scrollbar-color:rgba(67,80,114,0.25) transparent;}
#catalog-filters .filter-content::-webkit-scrollbar{width:6px;}
#catalog-filters .filter-content::-webkit-scrollbar-thumb{
  background:rgba(67,80,114,0.25);
  border-radius:999px;
}

.filters-handle{display:none;}

#filters-footer{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:1rem;
  padding-top:1rem;
}

#filters-summary{
  display:flex;
  flex-direction:column;
  gap:.4rem;
  background:rgba(255,255,255,0.88);
  border-radius:20px;
  border:1px solid rgba(210,218,235,0.45);
  padding:.75rem 1rem;
  box-shadow:0 12px 24px rgba(24,40,72,0.08);
}

.filters-summary-heading{
  font-size:.85rem;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:#8a8a8a;
}

#filters-summary-text{
  display:flex;
  flex-wrap:wrap;
  gap:.35rem;
  align-items:flex-start;
}

#filters-summary-text.empty{
  gap:0;
}

@media (max-width:767px){
  #filters-summary{
    padding:.65rem .9rem;
  }
  #filters-summary-text{
    max-height:7.5rem;
    overflow:auto;
    padding-right:.25rem;
    gap:.3rem;
  }
  #filters-summary-text::-webkit-scrollbar{
    width:4px;
  }
  #filters-summary-text::-webkit-scrollbar-thumb{
    background:rgba(24,40,72,0.18);
    border-radius:999px;
  }
}

.filter-summary-empty{
  font-size:.95rem;
  color:#6f6f6f;
}

.filter-chip{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  border:none;
  border-radius:0;
  padding:0;
  margin:0;
  background:none;
  color:#6f6655;
  cursor:pointer;
  font-size:.9rem;
  line-height:1.25;
  font-weight:500;
  transition:color .2s ease,text-decoration-color .2s ease;
  max-width:100%;
  flex-wrap:wrap;
  text-decoration:none;
  box-shadow:none;
}

.filter-chip:focus-visible,
.filter-chip:hover{
  color:#4c4232;
  text-decoration:underline;
  text-decoration-color:rgba(76,66,50,0.6);
  text-decoration-thickness:0.08em;
  text-underline-offset:0.25em;
  outline:2px solid rgba(243,175,61,0.38);
  outline-offset:2px;
  box-shadow:none;
}

.filter-chip:active{
  color:#3b3225;
}

.filter-chip-remove{
  font-size:1rem;
  line-height:1;
}

.filter-chip-label{
  white-space:normal;
  word-break:break-word;
}

.filters-footer-actions{display:flex;gap:.5rem;}

.filters-footer-actions button{
  flex:1;
  font-weight:600;
  transition:transform .24s var(--catalog-ease-out),
    box-shadow .24s var(--catalog-ease-out),
    background-color .24s ease,
    color .24s ease;
}

@media (max-width:1023px){
  #catalog-filters{
    width:min(640px, calc(100vw - 1.5rem));
    max-width:calc(100vw - 1rem);
    margin:0;
    position:fixed;
    left:50%;
    right:auto;
    bottom:0;
    height:80vh;
    max-height:90vh;
    background:linear-gradient(160deg,rgba(255,255,255,0.96) 0%,rgba(255,248,237,0.94) 45%,rgba(255,255,255,0.9) 100%);
    backdrop-filter:none;
    z-index:1500;
    padding:2rem 1.75rem calc(env(safe-area-inset-bottom,0) + 2rem);
    box-shadow:0 -32px 64px rgba(0,0,0,0.22);
    border-radius:28px 28px 0 0;
    border:1px solid rgba(17,17,17,0.08);
    transform:translate(-50%, 100%);
    opacity:0;
    pointer-events:none;
    transition:transform .32s ease, opacity .32s ease;
    display:flex;
    flex-direction:column;
    gap:1.15rem;
  }
  #catalog-filters.show{
    transform:translate(-50%, 0);
    opacity:1;
    pointer-events:auto;
  }
  #catalog-filters .filter-group{width:100%;}
  #catalog-filters .filter-content{
    margin:0;
    padding:0 .35rem calc(env(safe-area-inset-bottom,0) + 8.5rem);
  }
  #filters-open{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    margin:0 auto 1.25rem .75rem;
    padding:.45rem 1.1rem;
    background:rgba(255,255,255,0.95);
    color:var(--color-orange,#f3af3d);
    border:1px solid rgba(243,175,61,0.35);
    border-radius:999px;
    font-size:.95rem;
    font-weight:600;
    box-shadow:0 12px 28px rgba(0,0,0,0.12);
    align-self:flex-start;
  }
  #filters-open svg{width:20px;height:20px;}
  #filters-close{
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(255,255,255,0.88);
    border:none;
    font-size:1.35rem;
    position:absolute;
    top:calc(env(safe-area-inset-top,0) + .75rem);
    right:calc(env(safe-area-inset-right,0) + 1rem);
    padding:.35rem;
    border-radius:999px;
    box-shadow:0 8px 18px rgba(0,0,0,0.08);
    color:#4d4d4d;
  }
  #filters-close:focus-visible{
    outline:2px solid rgba(243,175,61,0.6);
    outline-offset:2px;
  }
  .filters-handle{
    display:block;
    width:44px;
    height:4px;
    border-radius:999px;
    background:rgba(0,0,0,0.18);
    margin:2rem auto 0.75rem;
  }
  #filters-footer{
    position:sticky;
    bottom:0;
    padding-bottom:calc(env(safe-area-inset-bottom,0) + .65rem);
    backdrop-filter:blur(18px);
    padding-left:1.35rem;
    padding-right:1.35rem;
    margin-left:-.35rem;
    margin-right:-.35rem;
    padding-top:.85rem;
    gap:.85rem;
    z-index:1;
  }
  #filters-footer::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    top:-1rem;
    background:linear-gradient(to top, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.88) 55%, rgba(255,255,255,0.6) 100%);
    z-index:-1;
    border-radius:24px 24px 0 0;
    pointer-events:none;
  }
  #filters-summary-text{
    font-size:1rem;
  }
  .filters-footer-actions{
    gap:.75rem;
  }
  .filters-footer-actions button{
    padding:.85rem 1.05rem;
    min-height:44px;
    font-size:.92rem;
    border-radius:12px;
  }
}

@media (min-width:1024px){
  #catalog-filters{
    position:sticky;
    top:1rem;
    max-height:calc(100vh - 2rem);
  }
}

@media (min-width:1024px){
  #filters-open{display:none;}
}

@media (max-width:600px){
  #filters-open{
    font-size:.9rem;
  }
  .catalog-card{
    border-radius:20px;
  }
  .catalog-card__media{
    aspect-ratio:16/9;
  }
  .catalog-card__content{
    padding:0.85rem 1rem 1rem;
    gap:.65rem;
  }
  .catalog-card__title{
    font-size:1rem;
  }
  .catalog-card__price{
    padding:.35rem .6rem;
  }
  .catalog-card__footer{
    flex-direction:column;
    align-items:stretch;
    gap:.6rem;
  }
  .catalog-card__stat{
    width:100%;
    text-align:center;
  }
  .catalog-card__cta{
    width:100%;
    min-width:0;
    display:flex;
    justify-content:center;
    box-sizing:border-box;
  }
}

.tilda-catalog{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(1rem,2vw,1.75rem);
  margin:0;
  flex:1;
  width:100%;
}

@media (max-width:767px){
  .tilda-catalog{
    grid-template-columns:minmax(0,1fr);
    justify-items:stretch;
  }
  .tilda-catalog .catalog-card{
    width:100%;
  }
}

@media (min-width:1280px){
  .tilda-catalog{grid-template-columns:repeat(3,1fr);}
}

.leaflet-popup-content{margin:0;font-family:'Nunito',sans-serif;}
.leaflet-popup-content-wrapper{padding:0;border-radius:24px;overflow:hidden;}
.leaflet-popup-content .catalog-card{width:260px;font-family:'Nunito',sans-serif;}
.catalog-card{
  position:relative;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
  max-width:100%;
  border-radius:24px;
  overflow:hidden;
  background:linear-gradient(180deg,#ffffff 0%,#fff9f9 100%);
  border:1px solid rgba(210,218,235,0.6);
  box-shadow:0 22px 48px rgba(24,40,72,0.12);
  cursor:pointer;
  transition:transform .35s var(--catalog-ease-out),box-shadow .35s var(--catalog-ease-out);
  min-height:100%;
  isolation:isolate;
}
.catalog-card:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 56px rgba(22,36,64,0.18);
}
.catalog-card__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#fff9f9;
}
.catalog-card__image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform-origin:center;
  transition:transform .45s var(--catalog-ease-out);
}
.catalog-card:hover .catalog-card__image{
  transform:scale(1.05);
}
.catalog-card__placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.95rem;
  color:#5a6278;
  background:linear-gradient(135deg,rgba(243,175,61,0.15) 0%,rgba(242,209,131,0.15) 45%,rgba(243,175,61,0.15) 100%);
  text-align:center;
  padding:1rem;
}
.catalog-card__badges{
  position:absolute;
  top:1rem;
  left:1rem;
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
  z-index:2;
}
.catalog-card__badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-size:.7rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  padding:.35rem .65rem;
  border-radius:999px;
  background:linear-gradient(120deg,rgba(63,81,181,0.85) 0%,rgba(123,97,255,0.85) 100%);
  color:#fff;
  box-shadow:0 6px 14px rgba(91,110,219,0.25);
}
.catalog-card__badge--verified{
  background:linear-gradient(120deg,rgba(34,177,115,0.92) 0%,rgba(16,124,77,0.92) 100%);
  box-shadow:0 6px 14px rgba(25,133,87,0.25);
}
.catalog-card__badge--over-market{
  background:linear-gradient(120deg,rgba(245,101,101,0.92) 0%,rgba(201,42,54,0.92) 100%);
  box-shadow:0 6px 14px rgba(201,59,82,0.25);
}
.catalog-card__badge--verified svg{
  width:.85rem;
  height:.85rem;
  stroke:currentColor;
}
.catalog-card__badge--verified span{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
}
.catalog-card__rating{
  position:absolute;
  bottom:1rem;
  right:1rem;
  display:flex;
  align-items:baseline;
  gap:.15rem;
  padding:.45rem .75rem;
  border-radius:14px;
  background:rgba(17,25,40,0.75);
  color:#fff;
  font-weight:600;
  font-size:.95rem;
  box-shadow:0 12px 24px rgba(17,25,40,0.25);
}
.catalog-card__rating-value{font-size:1.05rem;}
.catalog-card__rating-max{opacity:.65;font-size:.75rem;}
.catalog-card__content{
  display:flex;
  flex-direction:column;
  gap:1rem;
  padding:1.1rem 1.35rem 1.4rem;
}
.catalog-card__header{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.75rem;
}
.catalog-card__title{
  margin:0;
  font-size:1.15rem;
  font-weight:700;
  color:#1f2a44;
  line-height:1.35;
  width:100%;
  word-break:normal;
  overflow-wrap:break-word;
}
.catalog-card__price{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  background:rgba(243,175,61,0.16);
  color:#d9861a;
  border-radius:14px;
  padding:.45rem .75rem;
  font-weight:600;
  align-self:flex-start;
  max-width:100%;
  box-sizing:border-box;
}
.catalog-card__price-text{
  display:inline-flex;
  align-items:baseline;
  gap:.35rem;
  white-space:nowrap;
}
.catalog-card__amount{font-size:1.05rem;line-height:1;}
.catalog-card__currency{font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;line-height:1;}
.catalog-card__location{
  margin:0;
  display:flex;
  align-items:center;
  gap:.45rem;
  color:#435072;
  font-size:.92rem;
}
.catalog-card__location svg{
  width:18px;
  height:18px;
  stroke:currentColor;
}
.catalog-card__meta,
.catalog-card__tags{
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
}
.catalog-card__meta-chip,
.catalog-card__tag{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:.35rem .7rem;
  border-radius:999px;
  background:rgba(67,80,114,0.08);
  color:#36405f;
  font-size:.82rem;
  line-height:1.1;
}
.catalog-card__meta-chip svg{
  width:16px;
  height:16px;
  stroke:currentColor;
}
.catalog-card__tag--pool{background:rgba(55,176,170,0.12);color:#1f7f76;}
.catalog-card__tag--view{background:rgba(63,81,181,0.12);color:#3f51b5;}
.catalog-card__tag--type{background:rgba(255,138,101,0.16);color:#d6653a;}
.catalog-card__tag--bedrooms{background:rgba(129,199,132,0.16);color:#3e8143;}
.catalog-card__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  margin-top:auto;
  flex-wrap:wrap;
  width:100%;
}
.catalog-card__stat{
  font-size:.8rem;
  color:#62708e;
  background:rgba(98,112,142,0.12);
  padding:.4rem .65rem;
  border-radius:12px;
  white-space:nowrap;
}
.catalog-card__cta{
  border:none;
  border-radius:18px;
  padding:.6rem 1.5rem;
  background:var(--catalog-button-bg);
  color:var(--catalog-button-text);
  font-weight:600;
  font-size:.95rem;
  cursor:pointer;
  transition:transform .2s var(--catalog-ease-out),box-shadow .2s var(--catalog-ease-out),background-color .2s ease;
  min-width:fit-content;
}
.catalog-card__cta:focus-visible,
.catalog-card__cta:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px rgba(249,123,34,0.28);
  outline:none;
  background:var(--catalog-button-bg-hover);
}
.catalog-card__cta:active{
  transform:translateY(1px);
  box-shadow:none;
}

.copy-toast{
  position:fixed;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  background:rgba(0,0,0,0.8);
  color:#fff;
  padding:.5rem 1rem;
  border-radius:8px;
  font-size:.875rem;
  font-family:'Nunito',sans-serif;
  z-index:2000;
  pointer-events:none;
  opacity:0;
  transition:opacity .3s;
}
.copy-toast.show{opacity:1;}

.view-entering{animation:catalogViewIn .32s var(--catalog-ease-out) both;}
.view-leaving{animation:catalogViewOut .22s var(--catalog-ease-in) forwards;}

.tilda-catalog.is-loading{pointer-events:none;}
.tilda-catalog.has-skeleton{min-height:260px;}
.catalog-card.skeleton{
  background:linear-gradient(180deg,rgba(255,255,255,0.95) 0%,rgba(244,246,252,0.95) 100%);
  border:1px solid rgba(210,218,235,0.5);
  box-shadow:0 18px 40px rgba(24,40,72,0.08);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  padding:0;
  pointer-events:none;
}
.catalog-card.skeleton .skeleton-thumb{
  width:100%;
  aspect-ratio:4/3;
  background:var(--catalog-skeleton-bg);
  background-size:200% 100%;
  animation:shimmer 1.35s linear infinite;
}
.catalog-card.skeleton .skeleton-info{
  display:flex;
  flex-direction:column;
  gap:.6rem;
  padding:1rem 1.25rem 1.25rem;
}
.catalog-card.skeleton .skeleton-line{
  height:14px;
  border-radius:999px;
  background:var(--catalog-skeleton-bg);
  background-size:200% 100%;
  animation:shimmer 1.35s linear infinite;
}
.catalog-card.skeleton .skeleton-line.title{height:18px;width:64%;}
.catalog-card.skeleton .skeleton-line.subtitle{width:48%;}
.catalog-card.skeleton .skeleton-line.meta{width:84%;}
.catalog-card.skeleton .skeleton-line.short{width:38%;}

@media (max-width:600px){
  .catalog-card.skeleton .skeleton-thumb{aspect-ratio:3/2;}
  .catalog-card.skeleton .skeleton-info{padding:.85rem 1rem 1rem;gap:.5rem;}
  .catalog-card.skeleton .skeleton-line{height:12px;}
}

.shimmer{
  background-image:var(--catalog-skeleton-bg);
  background-size:200% 100%;
  animation:shimmer 1.5s linear infinite;
}

.catalog-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  gap:.35rem;
  margin:1rem auto 0;
  padding:.45rem .65rem;
  grid-column:1/-1;
  border-radius:18px;
  background:rgba(255,255,255,0.88);
  border:1px solid rgba(241,138,47,0.14);
  box-shadow:0 10px 22px rgba(243,175,61,0.16);
}
.catalog-pagination button{
  min-width:34px;
  min-height:34px;
  padding:.2rem .55rem;
  border-radius:11px;
  border:1px solid rgba(243,175,61,0.2);
  background:rgba(243,175,61,0.08);
  color:#80420a;
  font-weight:600;
  font-size:.84rem;
  letter-spacing:.01em;
  cursor:pointer;
  box-shadow:0 6px 16px rgba(243,175,61,0.18);
  transition:transform .22s var(--catalog-ease-out),box-shadow .22s var(--catalog-ease-out),background .2s ease,color .2s ease;
}
.catalog-pagination button:hover,
.catalog-pagination button:focus-visible{
  background:rgba(243,175,61,0.18);
  color:#5d2f04;
  box-shadow:0 10px 22px rgba(243,175,61,0.22);
  outline:none;
  transform:translateY(-1px);
}
.catalog-pagination button:active{
  transform:scale(0.97);
}
.catalog-pagination button.active{
  background:var(--catalog-amber-gradient-main);
  color:#1f1f1f;
  border-color:rgba(241,138,47,0.26);
  box-shadow:0 12px 24px rgba(241,138,47,0.24);
}
.catalog-pagination button:disabled{
  cursor:not-allowed;
  opacity:.6;
  box-shadow:none;
  transform:none;
  background:rgba(243,175,61,0.06);
  color:#b9a68a;
  border-color:rgba(243,175,61,0.14);
}
.catalog-pagination span.dots{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  height:32px;
  padding:.2rem .45rem;
  border-radius:10px;
  background:rgba(33,36,44,0.05);
  color:#5c6068;
  font-weight:600;
  letter-spacing:.06em;
}
@media (max-width:600px){
  .catalog-pagination{
    margin:.85rem auto 0;
    padding:.35rem .55rem;
    gap:.25rem;
    border-radius:16px;
  }
  .catalog-pagination button,
  .catalog-pagination span.dots{
    min-width:30px;
    height:30px;
    font-size:.8rem;
    padding:.18rem .4rem;
  }
}
#catalog-controls{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:clamp(.75rem,2vw,1.5rem);
  margin:0;
  position:relative;
  width:100%;
}
#catalog-controls .currency-switch{
  display:flex;
  align-items:center;
  gap:.5rem;
  font-weight:600;
  color:#3b3f49;
  background:rgba(255,255,255,0.86);
  padding:.45rem .85rem;
  border-radius:999px;
  border:1px solid var(--catalog-card-border);
  box-shadow:0 12px 24px rgba(17,17,17,0.06);
}
#catalog-controls .currency-switch select{
  appearance:none;
  border:none;
  background:transparent;
  font-weight:600;
  color:inherit;
  padding:.1rem .25rem;
  font-family:'Nunito',sans-serif;
  cursor:pointer;
  min-width:8rem;
}
#catalog-controls .currency-switch option{
  font-family:'Nunito',sans-serif;
}
#catalog-controls .currency-switch select:focus-visible{
  outline:2px solid rgba(243,175,61,0.45);
  outline-offset:2px;
}
#catalog-controls .currency-switch__title{
  font-size:.9rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#676b73;
}
.currency-notice{
  flex:1 1 100%;
  margin:0;
  font-size:.85rem;
  color:#5c6068;
  line-height:1.4;
}
.currency-notice[hidden]{
  display:none !important;
}
#catalog-controls.has-pref-prompt{
  padding-top:.5rem;
}
@media (max-width:600px){
  #catalog-controls{justify-content:space-between;}
}
.catalog-preferences-prompt{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex:1 1 100%;
  max-width:min(100%,640px);
  margin:0 auto;
  background:var(--catalog-card-surface);
  color:#2f2f33;
  padding:1rem 1.25rem;
  border-radius:28px;
  border:1px solid var(--catalog-card-border);
  box-shadow:var(--catalog-card-shadow);
  position:relative;
  overflow:hidden;
  animation:catalogViewIn .32s var(--catalog-ease-out);
}
.catalog-preferences-prompt::before{
  content:"";
  position:absolute;
  inset:-35% -10% 5% -20%;
  background:linear-gradient(135deg,rgba(243,175,61,0.24) 0%,rgba(241,138,47,0.18) 45%,rgba(248,210,125,0.22) 100%);
  filter:blur(32px);
  opacity:1;
  pointer-events:none;
  z-index:0;
}
.catalog-preferences-prompt>*{position:relative;z-index:1;}

.catalog-pref-hide{
  opacity:0;
  transform:translateY(-6px);
  transition:opacity .2s var(--catalog-ease-in),transform .2s var(--catalog-ease-in);
}

.catalog-pref-text{
  flex:1 1 auto;
  min-width:0;
  font-size:1rem;
  line-height:1.45;
  font-weight:500;
  white-space:normal;
  color:inherit;
}

.catalog-pref-actions{
  display:flex;
  gap:.5rem;
  flex-wrap:nowrap;
}

.catalog-pref-actions button{
  border:1px solid var(--catalog-card-border);
  border-radius:999px;
  font-size:.9rem;
  padding:.5rem 1.1rem;
  cursor:pointer;
  font-weight:600;
  color:#2f2f33;
  background:#fff;
  box-shadow:0 12px 24px rgba(17,17,17,0.08);
  transition:background-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;
  box-sizing:border-box;
}

.catalog-pref-apply{
  background:var(--catalog-button-bg);
  color:var(--catalog-button-text);
  border:none;
  box-shadow:0 18px 36px rgba(243,175,61,0.35);
}

.catalog-pref-apply:hover,
.catalog-pref-apply:focus{
  background:var(--catalog-button-bg-hover);
  color:var(--catalog-button-text);
  box-shadow:0 24px 44px rgba(243,175,61,0.45);
}

.catalog-pref-skip{
  background:rgba(255,255,255,0.92);
  color:#2f2f33;
}

.catalog-pref-skip:hover,
.catalog-pref-skip:focus{
  background:#fff;
  color:#2f2f33;
  box-shadow:0 16px 32px rgba(17,17,17,0.12);
}

@media (max-width:767px){
  .catalog-preferences-prompt{
    flex-direction:column;
    align-items:flex-start;
    width:100%;
    max-width:100%;
    border-radius:22px;
    padding:.9rem 1rem;
  }
  .catalog-pref-text{
    white-space:normal;
  }
  .catalog-pref-actions{
    width:100%;
  }
  .catalog-pref-actions button{
    flex:1;
    width:100%;
    padding:.6rem 1rem;
  }
}

@media (prefers-reduced-motion:reduce){
  .catalog-preferences-prompt{
    animation:none;
  }
  .catalog-pref-hide{
    transition:none;
  }
}
#catalog-controls .view-toggle{
  margin:0;
  display:flex;
  align-items:center;
  gap:.3rem;
  padding:.35rem .4rem;
  border-radius:18px;
  background:rgba(255,255,255,0.9);
  border:1px solid rgba(241,138,47,0.16);
  box-shadow:0 12px 24px rgba(243,175,61,0.14);
}
.view-toggle{margin:0;display:flex;align-items:center;gap:.25rem;}
#catalog-map{min-height:800px;border-radius:8px;flex:1;display:none;}
.leaflet-attribution-flag{display:none!important;}
.view-toggle .view-btn{
  background:rgba(243,175,61,0.08);
  border:1px solid rgba(243,175,61,0.2);
  width:34px;
  height:34px;
  padding:0;
  border-radius:12px;
  cursor:pointer;
  font-size:.85rem;
  color:#8b4a09;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .24s var(--catalog-ease-out),color .2s ease,box-shadow .24s var(--catalog-ease-out),background-color .2s ease,border-color .2s ease;
  will-change:transform;
  box-shadow:0 6px 14px rgba(243,175,61,0.18);
}
.view-toggle .view-btn::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg,rgba(243,175,61,0.18) 0%,rgba(243,175,61,0.28) 100%);
  opacity:0;
  transition:opacity .24s ease;
  z-index:-1;
}
.view-toggle .view-btn.active{
  background:var(--catalog-amber-gradient-main);
  color:#1f1f1f;
  border-color:rgba(241,138,47,0.28);
  box-shadow:0 10px 22px rgba(241,138,47,0.24);
}
.view-toggle .view-btn.active::after{opacity:0;}
.view-toggle .view-btn:hover{
  transform:translateY(-1px);
  background:rgba(243,175,61,0.16);
  box-shadow:0 8px 18px rgba(243,175,61,0.2);
}
.view-toggle .view-btn.active:hover{
  background:var(--catalog-amber-gradient-main);
  box-shadow:0 12px 26px rgba(241,138,47,0.26);
}
.view-toggle .view-btn:active{transform:scale(0.95);}
.view-toggle .view-btn svg{width:18px;height:18px;transition:transform .24s var(--catalog-ease-out);}
.view-toggle .view-btn:hover svg{transform:scale(1.04);}
.view-toggle .view-btn:focus-visible{outline:2px solid rgba(243,175,61,0.35);outline-offset:2px;}
.view-toggle .map-style-select{
  height:34px;
  padding:0 .65rem;
  margin-left:.4rem;
  border-radius:14px;
  border:1px solid rgba(241,138,47,0.2);
  background:rgba(255,255,255,0.95);
  font-size:.82rem;
  color:#8b4a09;
  box-shadow:0 6px 16px rgba(243,175,61,0.16);
}
.modal-map{height:300px;margin-top:1rem;border-radius:8px;}

#catalog-filters .filter-group{
  display:flex;
  flex-direction:column;
  gap:.75rem;
  padding:1rem 1.15rem;
  border-radius:20px;
  background:linear-gradient(150deg,#ffffff 0%,#fff8ec 100%);
  border:1px solid rgba(243,175,61,0.22);
  box-shadow:0 18px 36px rgba(243,175,61,0.18);
  box-sizing:border-box;
}
#catalog-filters .filter-group h4{margin:0;font-size:1rem;}
#catalog-filters .filter-group .options{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}
#catalog-filters .filter-group--dates{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.75rem 1rem;
  align-items:end;
}
#catalog-filters .filter-group--dates h4{
  font-size:.95rem;
  color:#55607a;
  align-self:end;
  margin-bottom:0;
}
#catalog-filters .filter-group--dates input[type=date]{
  width:100%;
}
#catalog-filters input[type=date],
#catalog-filters select{
  width:100%;
  font-family:'Nunito',sans-serif;
  font-size:.95rem;
  color:#1f2a44;
  padding:.65rem .85rem;
  border:1px solid rgba(67,80,114,0.18);
  border-radius:14px;
  background:rgba(255,255,255,0.95);
  box-shadow:0 8px 18px rgba(17,17,17,0.08);
  box-sizing:border-box;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
#catalog-filters input[type=date]:focus-visible,
#catalog-filters select:focus-visible{
  outline:none;
  border-color:rgba(243,175,61,0.45);
  box-shadow:0 0 0 3px rgba(243,175,61,0.18);
  background:rgba(255,255,255,1);
}
#catalog-filters .filter-option{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.45rem .75rem;
  border-radius:14px;
  border:1px solid transparent;
  background:rgba(67,80,114,0.1);
  color:#2f3653;
  font-size:.85rem;
  line-height:1.2;
  cursor:pointer;
  transition:background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  flex-wrap:wrap;
  max-width:100%;
}
#catalog-filters .filter-option:hover{
  background:rgba(243,175,61,0.14);
  color:#7f4b02;
}
#catalog-filters .filter-option:focus-within{
  outline:2px solid rgba(243,175,61,0.35);
  outline-offset:3px;
}
#catalog-filters .filter-option.is-active{
  background:rgba(243,175,61,0.2);
  border-color:rgba(243,175,61,0.32);
  color:#6b3b00;
  box-shadow:0 8px 18px rgba(243,175,61,0.22);
}
#catalog-filters .filter-option input[type=checkbox]{
  margin:0;
  width:18px;
  height:18px;
  accent-color:var(--color-orange,#f3af3d);
}
#catalog-filters .filter-option span{
  white-space:normal;
  flex:1 1 auto;
  min-width:0;
  word-break:break-word;
}

@media (max-width:767px){
  #catalog-filters .filter-option{
    width:100%;
  }
}
#catalog-filters button{
  padding:.6rem 1.15rem;
  border:none;
  border-radius:16px;
  background:var(--catalog-button-bg);
  color:var(--catalog-button-text);
  cursor:pointer;
  margin-top:.5rem;
  font-weight:600;
  font-size:.95rem;
  box-shadow:0 12px 28px rgba(241,138,47,0.28);
  transition:transform .2s var(--catalog-ease-out),box-shadow .2s var(--catalog-ease-out),background-color .2s ease;
}
#catalog-filters button:hover,
#catalog-filters button:focus-visible{
  transform:translateY(-1px);
  background:var(--catalog-button-bg-hover);
}
#catalog-filters button:hover{
  box-shadow:0 14px 30px rgba(241,138,47,0.32);
}
#catalog-filters .filters-footer-actions button{
  border-radius:18px;
  margin-top:0;
  border:none;
}
#filters-summary .filter-chip{
  padding:0;
  margin:0;
  background:none;
  color:#6f6655;
  border:none;
  border-radius:0;
  box-shadow:none;
}
#filters-summary .filter-chip:hover,
#filters-summary .filter-chip:focus-visible{
  background:none;
  box-shadow:none;
  transform:none;
}
#filters-summary .filter-chip:active{
  transform:none;
}
#catalog-filters button:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(243,175,61,0.28), 0 16px 34px rgba(241,138,47,0.34);
}
#catalog-filters button:disabled{opacity:.6;cursor:not-allowed;}

#reset-filters{
  background:rgba(255,255,255,0.96);
  color:var(--color-orange,#f3af3d);
  border:1px solid rgba(243,175,61,0.28);
  box-shadow:0 0 0 1px rgba(243,175,61,0.18);
}
#reset-filters:hover{
  background:rgba(243,175,61,0.12);
  transform:none;
  box-shadow:0 0 0 1px rgba(243,175,61,0.24);
}
#reset-filters:focus-visible{
  transform:none;
  box-shadow:0 0 0 1px rgba(243,175,61,0.24);
}
#reset-filters:active{
  transform:scale(0.98);
}

#apply-filters{
  background:var(--catalog-amber-gradient-main);
  box-shadow:0 14px 32px rgba(241,138,47,0.35);
  font-weight:700;
}
#apply-filters:hover{
  box-shadow:0 18px 38px rgba(241,138,47,0.4);
  transform:translateY(-1px);
}
#apply-filters:active{
  transform:translateY(0);
  box-shadow:0 8px 18px rgba(243,175,61,0.26);
}
#apply-filters:disabled{
  box-shadow:none;
  transform:none;
}

@media (min-width:1024px){
  #catalog-filters{position:sticky;top:1rem;}
}

#catalog-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.6);display:none;align-items:center;justify-content:center;z-index:1000;padding:clamp(1.5rem,4vw,3rem);box-sizing:border-box;font-family:'Nunito',sans-serif;}
#catalog-modal.show{display:flex;}
#catalog-modal .modal-content{position:relative;background:#fff;padding:0;border-radius:32px;overflow:hidden;max-height:94vh;max-height:min(94vh,1040px);width:min(100%,980px);margin:0 auto;display:flex;flex-direction:column;box-shadow:0 32px 64px rgba(17,17,17,0.18);}
#catalog-modal .close-wrapper{position:sticky;top:0;width:100%;height:0;z-index:2;}
#catalog-modal .modal-close{position:absolute;top:clamp(.85rem,2vw,1.2rem);right:clamp(.85rem,2vw,1.2rem);display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:18px;border:none;background:rgba(24,26,32,0.58);color:#fff;font-size:1.9rem;line-height:1;cursor:pointer;box-shadow:0 22px 46px rgba(0,0,0,0.32);backdrop-filter:blur(12px);transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease,color .25s ease;}
#catalog-modal .modal-close span{display:flex;align-items:center;justify-content:center;line-height:1;}
#catalog-modal .modal-close:hover,#catalog-modal .modal-close:focus-visible{background:rgba(16,17,22,0.78);box-shadow:0 28px 58px rgba(0,0,0,0.38);transform:translateY(-1px);outline:none;}
#catalog-modal .modal-close:active{transform:scale(0.94);box-shadow:0 16px 36px rgba(0,0,0,0.32);}
#catalog-modal .modal-body{display:flex;flex-direction:column;gap:clamp(1.2rem,3vw,2.8rem);flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:clamp(1.2rem,3vw,2.4rem);}
#catalog-modal.loading .modal-body{justify-content:flex-start;align-items:stretch;}

.modal-skeleton{display:flex;flex-direction:column;gap:clamp(1.25rem,3vw,2.2rem);width:100%;padding:clamp(1.8rem,4vw,2.6rem) clamp(1.6rem,5vw,3rem);box-sizing:border-box;}
.modal-skeleton__hero{width:100%;aspect-ratio:4/3;border-radius:32px;box-shadow:0 22px 44px rgba(17,17,17,0.12);}
.modal-skeleton__section{display:flex;flex-direction:column;gap:.8rem;}
.modal-skeleton__chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem;}
.modal-skeleton__chip{height:28px;min-width:96px;border-radius:999px;}
.modal-skeleton__line{height:15px;border-radius:999px;}
.modal-skeleton__line--title{height:24px;width:62%;}
.modal-skeleton__line--subtitle{width:48%;}
.modal-skeleton__calendar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:.5rem;}
.modal-skeleton__calendar-cell{height:68px;border-radius:20px;}

#catalog-modal.has-error .modal-body{justify-content:center;align-items:center;}
.modal-error{width:100%;max-width:520px;padding:clamp(2rem,5vw,3rem) clamp(1.75rem,6vw,3.25rem);margin:0 auto;background:rgba(255,255,255,0.94);border-radius:28px;border:1px solid rgba(17,17,17,0.08);box-shadow:0 28px 56px rgba(17,17,17,0.12);text-align:center;}
.modal-error__icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:rgba(192,58,43,0.12);color:#c03a2b;margin:0 auto 1rem;}
.modal-error__icon svg{width:36px;height:36px;}
.modal-error__message{margin:0;font-size:1.02rem;line-height:1.6;color:#3c4663;}

@media (max-width:600px){
  .modal-skeleton{padding:clamp(1.5rem,6vw,2.1rem) clamp(1.1rem,6vw,1.6rem);gap:clamp(1rem,4vw,1.6rem);}
  .modal-skeleton__hero{aspect-ratio:3/2;border-radius:26px;}
  .modal-skeleton__calendar{grid-template-columns:repeat(2,minmax(0,1fr));}
  .modal-skeleton__calendar-cell{height:60px;border-radius:18px;}
  .modal-error{padding:clamp(1.6rem,6vw,2.4rem) clamp(1.25rem,6vw,2rem);border-radius:24px;}
  .modal-error__icon{width:64px;height:64px;}
  .modal-error__icon svg{width:30px;height:30px;}
}

#catalog-modal .modal-heading{margin:0;font-size:clamp(1.8rem,3vw,2.75rem);font-weight:700;color:#1f1f1f;text-align:left;text-transform:capitalize;padding:0;letter-spacing:-0.01em;line-height:1.1;}
#catalog-modal .modal-photos{display:flex;flex-direction:column;align-items:center;gap:0;}
#catalog-modal .modal-hero{position:relative;margin:-3.5rem clamp(1.9rem,4.6vw,3rem) 0;padding:clamp(1.75rem,4.5vw,2.6rem);padding-top:25px;padding-bottom:120px;border-radius:30px;background:linear-gradient(135deg,rgba(255,255,255,0.98) 0%,rgba(255,255,255,0.9) 100%);color:#1f1f1f;backdrop-filter:blur(10px);box-shadow:0 26px 52px rgba(17,17,17,0.12);display:flex;flex-direction:column;gap:clamp(1.35rem,3.6vw,2.35rem);border:1px solid rgba(17,17,17,0.06);overflow:hidden;isolation:isolate;box-sizing:border-box;flex:0 1 auto;}
#catalog-modal .modal-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(140% 140% at 12% 16%,rgba(243,175,61,0.24) 0%,rgba(243,175,61,0.08) 44%,rgba(255,255,255,0) 72%);pointer-events:none;opacity:.85;mix-blend-mode:screen;}
#catalog-modal .modal-hero > *{position:relative;z-index:1;}

#catalog-modal .modal-info{font-size:.9rem;padding:0;}
#catalog-modal .modal-info .price{font-size:1.2rem;font-weight:700;margin:.5rem 0 1rem;color:var(--color-orange,#f3af3d);}
#catalog-modal .modal-info p{margin:.25rem 0;}
#catalog-modal .modal-info .label{font-weight:600;margin-right:4px;}
#catalog-modal .calendar{width:100%;margin:0;font-size:1rem;display:flex;flex-direction:column;gap:.85rem;}
#catalog-modal .calendar-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.25rem;font-size:1rem;}
#catalog-modal .calendar-header span{font-weight:700;letter-spacing:.01em;text-transform:capitalize;color:#2a2a2a;}
#catalog-modal select.calendar-month-select{font-size:1rem;border-radius:16px;padding:.35rem .75rem;border:1px solid rgba(17,17,17,0.12);background:rgba(255,255,255,0.85);box-shadow:0 6px 16px rgba(17,17,17,0.08);cursor:pointer;}
#catalog-modal .calendar-nav{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:rgba(243,175,61,0.18);color:#b76c09;font-weight:700;cursor:pointer;transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease,color .25s ease;}
#catalog-modal .calendar-nav:hover,#catalog-modal .calendar-nav:focus-visible{background:rgba(243,175,61,0.28);color:#8a4d04;box-shadow:0 12px 28px rgba(243,175,61,0.32);outline:none;transform:translateY(-1px);}
#catalog-modal .calendar-nav:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none;}
#catalog-modal .calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;text-align:center;font-size:.95rem;}
#catalog-modal .calendar-grid .day-name{font-weight:600;color:#61646b;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em;}
#catalog-modal .calendar-day{position:relative;padding:12px 0;min-width:2rem;border-radius:18px;background:rgba(255,255,255,0.78);border:1px solid rgba(17,17,17,0.05);box-shadow:0 12px 28px rgba(17,17,17,0.08);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;cursor:default;}
#catalog-modal .calendar-day.other-month{color:#c1c4cc;background:rgba(244,246,250,0.6);border-style:dashed;box-shadow:none;}
#catalog-modal .calendar-day.busy{background:rgba(192,58,43,0.14);border-color:rgba(192,58,43,0.35);color:#a22d20;box-shadow:0 10px 24px rgba(192,58,43,0.18);}
#catalog-modal .calendar-day.available{cursor:pointer;}
#catalog-modal .calendar-day.available:hover,#catalog-modal .calendar-day.available:focus-visible{transform:translateY(-2px);box-shadow:0 18px 40px rgba(243,175,61,0.26);background:linear-gradient(135deg,rgba(243,175,61,0.22) 0%,rgba(243,175,61,0.36) 100%);color:#7f4b02;border-color:rgba(243,175,61,0.42);outline:none;}
#catalog-modal .calendar-day.tentative{background:rgba(250,251,255,0.72);color:#5c6068;border-style:dashed;cursor:help;}
#catalog-modal .calendar-day.tentative:hover,#catalog-modal .calendar-day.tentative:focus-visible{transform:none;box-shadow:0 12px 28px rgba(17,17,17,0.08);background:rgba(250,251,255,0.9);color:#4c4f57;border-color:rgba(17,17,17,0.12);outline:none;}
#catalog-modal .calendar-day.is-highlighted{background:linear-gradient(135deg,rgba(255,203,133,0.32) 0%,rgba(243,175,61,0.45) 100%);border-color:rgba(243,175,61,0.65);box-shadow:0 20px 44px rgba(243,175,61,0.32);color:#6b3b00;}
#catalog-modal .calendar-day.busy:focus-visible{outline:none;}
#catalog-modal .image-viewer{position:relative;width:100%;max-height:70vh;overflow:hidden;border-radius:32px 32px 0 0;}
#catalog-modal .image-viewer img{width:100%;height:auto;max-height:70vh;display:block;border-radius:32px 32px 0 0;object-fit:cover;margin:0;}

#catalog-modal .image-viewer__nav{position:absolute;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:18px;border:1px solid rgba(255,255,255,0.36);background:rgba(12,14,18,0.48);color:#fff;cursor:pointer;font-size:1.65rem;line-height:1;box-shadow:0 18px 42px rgba(0,0,0,0.28);backdrop-filter:blur(10px);transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease,border-color .25s ease;}
#catalog-modal .image-viewer__nav span{display:flex;align-items:center;justify-content:center;line-height:1;}
#catalog-modal .image-viewer__nav:hover,#catalog-modal .image-viewer__nav:focus-visible{background:rgba(12,14,18,0.7);border-color:rgba(255,255,255,0.55);box-shadow:0 24px 52px rgba(0,0,0,0.35);transform:translateY(-50%) translateY(-2px);outline:none;}
#catalog-modal .image-viewer__nav:active{transform:translateY(-50%) scale(0.94);box-shadow:0 14px 32px rgba(0,0,0,0.28);}
#catalog-modal .image-viewer__nav.image-viewer__nav--prev{left:clamp(.6rem,3vw,1.4rem);}
#catalog-modal .image-viewer__nav.image-viewer__nav--next{right:clamp(.6rem,3vw,1.4rem);}
#catalog-modal .thumbs{display:flex;gap:0;margin-top:0;overflow-x:auto;justify-content:flex-start;padding:0 .5rem;box-sizing:border-box;max-width:100%;}

#catalog-modal .thumbs img{flex:0 0 auto;width:80px;height:60px;object-fit:cover;cursor:pointer;opacity:1;border-radius:0;border:none;}
#catalog-modal .thumbs img.active{border:none;opacity:1;}

/* hero layout */
#catalog-modal .modal-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:clamp(1rem,3vw,1.5rem);
  min-height:clamp(3.6rem,4vw,4.5rem);
  padding-bottom:clamp(.4rem,1.6vw,.85rem);
}
#catalog-modal .modal-hero__header-actions{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  position:relative;
  z-index:2;
  min-height:56px;
  justify-self:end;
  align-self:start;
}
#catalog-modal .modal-hero__header{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:clamp(.95rem,2.6vw,1.35rem);
  min-width:0;
  width:100%;
  padding-block:.35rem;
}
#catalog-modal .modal-hero__title-stack{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:.55rem;
  min-width:0;
  flex:1 1 auto;
  min-height:56px;
}
#catalog-modal .modal-hero__title{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  gap:.5rem;
  min-width:0;
  width:100%;
}
#catalog-modal .modal-hero__title h3{
  margin:0;
  line-height:1.05;
}
#catalog-modal .modal-hero__meta{
  display:flex;
  flex-wrap:wrap;
  gap:clamp(.4rem,2vw,.75rem);
  margin:0;
  min-width:0;
  width:100%;
  align-items:center;
  overflow:hidden;
}
#catalog-modal .modal-hero__chip{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;border-radius:14px;background:rgba(33,36,44,0.08);color:#2f2f33;font-weight:600;font-size:clamp(.75rem,1.9vw,.92rem);letter-spacing:.01em;line-height:1.2;box-shadow:none;transition:background .2s ease,color .2s ease;}
#catalog-modal .modal-hero__chip svg{width:16px;height:16px;stroke:currentColor;color:inherit;opacity:1;}
#catalog-modal .modal-hero__chip:hover{background:rgba(33,36,44,0.12);color:#1f1f1f;}
#catalog-modal .modal-hero__chip--location{background:rgba(88,110,255,0.12);color:#3248bb;}
#catalog-modal .modal-hero__chip--district{background:rgba(36,189,162,0.12);color:#1f826b;}
#catalog-modal .modal-hero__chip--complex{background:rgba(243,175,61,0.16);color:#a45a06;}
#catalog-modal .modal-hero__chip--verified{background:rgba(31,151,103,0.16);color:#1f7d58;}
#catalog-modal .modal-hero__chip--verified svg{width:16px;height:16px;}
#catalog-modal .modal-hero__chip--bedrooms{background:rgba(33,36,44,0.08);color:#2f2f33;}
#catalog-modal .modal-hero__chip--pool{background:rgba(18,152,233,0.14);color:#116a9e;}
#catalog-modal .modal-hero__chip--view{background:rgba(255,202,133,0.18);color:#b35d05;}
#catalog-modal .modal-hero__chip--more{
  background:rgba(33,36,44,0.08);
  color:#2f2f33;
  cursor:default;
  white-space:nowrap;
}
#catalog-modal .modal-hero__chip--more[title]{
  cursor:help;
}

.icon-btn{
  background:none;
  border:none;
  color:var(--color-orange,#f3af3d);
  padding:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:color .24s ease,transform .28s var(--catalog-ease-out);
  will-change:transform;
}

.icon-btn.fav svg{
  stroke:currentColor;
  fill:none;
}

.icon-btn.fav.active{
  color:#e74c3c;
}

.icon-btn.fav.active svg{
  fill:currentColor;
}

.icon-btn:hover{transform:scale(1.06);}
.icon-btn:active{transform:scale(0.9);}
.icon-btn svg{
  width:24px;
  height:24px;
  transition:transform .28s var(--catalog-ease-out);
}
.icon-btn:hover svg{
  transform:scale(1.08);
}
.icon-btn.fav.fav-animate-add{animation:favButtonPop .4s var(--catalog-ease-out);}
#catalog-modal .modal-hero .icon-btn{width:48px;height:48px;border-radius:18px;background:#fff;border:1px solid rgba(17,17,17,0.08);color:#2f2f33;box-shadow:0 16px 32px rgba(17,17,17,0.14);transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease,color .25s ease;}
#catalog-modal .modal-hero .icon-btn svg{width:22px;height:22px;stroke:currentColor;}
#catalog-modal .modal-hero .icon-btn:hover,#catalog-modal .modal-hero .icon-btn:focus-visible{background:rgba(255,255,255,0.95);box-shadow:0 18px 36px rgba(17,17,17,0.18);color:#1c1c1e;outline:none;}
#catalog-modal .modal-hero .icon-btn:active{transform:scale(0.94);}
#catalog-modal .modal-hero .icon-btn.fav.active{background:rgba(231,76,60,0.18);color:#c03a2b;box-shadow:0 16px 32px rgba(231,76,60,0.28);border-color:rgba(231,76,60,0.32);}













.book-btn{background:var(--catalog-amber-gradient-main);color:#fff;border:none;border-radius:999px;padding:.85rem 1.75rem;cursor:pointer;white-space:nowrap;font-size:1rem;font-weight:700;letter-spacing:.01em;box-shadow:0 18px 36px rgba(241,138,47,0.35);transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),filter .25s ease;}
.book-btn{background:var(--catalog-button-bg);color:var(--catalog-button-text);}
.book-btn:hover,.book-btn:focus-visible{transform:translateY(-1px);box-shadow:0 24px 44px rgba(243,175,61,0.45);filter:drop-shadow(0 0 12px rgba(243,175,61,0.32));outline:none;background:var(--catalog-button-bg-hover);}
.book-btn:active{transform:scale(.98);}

@media (max-width:900px){
  #catalog-modal{align-items:flex-end;padding:0 clamp(.85rem,4vw,1.65rem) clamp(env(safe-area-inset-bottom) + 1rem,6vw,2.4rem);}
  #catalog-modal .modal-content{width:100%;max-width:100%;margin:0;border-radius:40px 40px 0 0;height:100%;max-height:100%;box-shadow:0 -12px 32px rgba(17,17,17,0.18);}
  #catalog-modal .modal-body{gap:clamp(1.05rem,4.4vw,2.1rem);padding-bottom:calc(env(safe-area-inset-bottom) + clamp(1.1rem,4.5vw,1.9rem));}
  #catalog-modal .modal-close{top:clamp(.75rem,4vw,1rem);right:clamp(.75rem,4vw,1rem);width:48px;height:48px;border-radius:16px;font-size:1.7rem;}
  #catalog-modal .image-viewer__nav{width:50px;height:50px;border-radius:16px;font-size:1.55rem;}
  #catalog-modal .modal-hero{display:flex;flex-direction:column;gap:clamp(1.05rem,4.2vw,1.75rem);margin:-2.6rem clamp(1.1rem,5vw,2rem) 0;padding:clamp(1.45rem,5vw,2.2rem);padding-top:25px;padding-bottom:120px;border-radius:34px;flex:0 0 auto;}
  #catalog-modal .modal-title-row{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:clamp(.75rem,4vw,1.25rem);}
  #catalog-modal .info-calendar{display:flex;flex-direction:column;gap:clamp(1rem,5vw,1.8rem);padding:0 clamp(1.25rem,5vw,2.1rem) clamp(1.5rem,5vw,2.3rem);}
  #catalog-modal .glass-card{padding:clamp(1.25rem,5vw,1.85rem);box-shadow:0 20px 46px rgba(17,17,17,0.14);width:100%;}
  #catalog-modal .booking-summary{position:relative;top:auto;z-index:auto;width:100%;}
  #catalog-modal .availability-card,#catalog-modal .property-details{width:100%;}
}

@media (max-width:768px){
  #catalog-modal .modal-hero{margin:-3rem clamp(1rem,5.2vw,1.9rem) 0;padding:clamp(1.45rem,5.4vw,2.1rem);padding-top:25px;padding-bottom:120px;flex:0 0 auto;}
  #catalog-modal .glass-card{padding:clamp(1.2rem,5.6vw,1.7rem);}
}

@media (max-width:640px){
  #catalog-modal{align-items:flex-end;}
  #catalog-modal .modal-content{width:100%;max-width:100%;margin:0;border-radius:40px 40px 0 0;max-height:100%;height:100%;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -10px 28px rgba(17,17,17,0.2);}
  #catalog-modal .modal-body{gap:clamp(1rem,5vw,2rem);padding-bottom:calc(env(safe-area-inset-bottom) + clamp(1rem,7vw,2rem));}
  #catalog-modal .close-wrapper{height:auto;}
  #catalog-modal .modal-close{width:44px;height:44px;border-radius:15px;font-size:1.55rem;top:clamp(.65rem,6vw,.9rem);right:clamp(.65rem,6vw,.9rem);}
  #catalog-modal .image-viewer__nav{width:46px;height:46px;border-radius:14px;font-size:1.4rem;}
  #catalog-modal .image-viewer__nav.image-viewer__nav--prev{left:clamp(.45rem,5.5vw,.9rem);}
  #catalog-modal .image-viewer__nav.image-viewer__nav--next{right:clamp(.45rem,5.5vw,.9rem);}
  #catalog-modal .modal-heading{font-size:clamp(1.35rem,6.4vw,1.75rem);}
  #catalog-modal .modal-hero{margin:-1.6rem clamp(1rem,6vw,1.6rem) 0;padding:clamp(1.25rem,5.4vw,1.65rem);padding-top:25px;padding-bottom:calc(env(safe-area-inset-bottom) + clamp(1rem,5.4vw,1.6rem));gap:clamp(.95rem,5.2vw,1.55rem);border-radius:30px;flex:0 0 auto;}
  #catalog-modal .modal-hero__header{grid-template-columns:minmax(0,1fr);grid-template-areas:"title" "actions";align-items:start;justify-items:stretch;row-gap:clamp(.75rem,5vw,1.2rem);padding-block:.2rem;}
  #catalog-modal .modal-title-row{grid-template-columns:minmax(0,1fr);grid-template-areas:"title" "actions";gap:clamp(.75rem,5vw,1.2rem);}
  #catalog-modal .modal-hero__title-stack{grid-area:title;}
  #catalog-modal .modal-hero__header-actions{grid-area:actions;padding-top:0;justify-self:end;align-self:end;}
  #catalog-modal .modal-hero__title{gap:.25rem;min-height:50px;}
  #catalog-modal .modal-hero__meta{margin:0;gap:.35rem;}
  #catalog-modal .modal-hero__header-actions{min-height:50px;}
  #catalog-modal .modal-hero__chip{justify-content:flex-start;font-size:clamp(.72rem,4vw,.88rem);padding:.42rem .8rem;gap:.3rem;}
  #catalog-modal .modal-hero__chip svg{width:15px;height:15px;}
  #catalog-modal .modal-hero .icon-btn{width:44px;height:44px;border-radius:16px;}
  #catalog-modal .modal-hero .icon-btn svg{width:20px;height:20px;}
  #catalog-modal .availability-card__header{align-items:stretch;}
  #catalog-modal .availability-card__cta{padding:.6rem 1rem;}
  #catalog-modal .info-calendar{display:flex;flex-direction:column;gap:clamp(1rem,6vw,1.6rem);padding:0 clamp(0.95rem,6vw,1.4rem) clamp(1.3rem,6vw,1.9rem);}
  #catalog-modal .booking-summary{position:relative;top:auto;z-index:auto;}
  #catalog-modal .booking-summary__cta{position:relative;bottom:auto;z-index:auto;}
  #catalog-modal .availability-card,#catalog-modal .property-details{flex:1 1 auto;width:100%;}
  #catalog-modal .calendar{font-size:.9rem;}
  #catalog-modal .calendar-day{padding:10px 0;}
  #catalog-modal .thumbs img{width:60px;height:45px;}
  #catalog-modal .similar-section{padding:0 clamp(.2rem,3.5vw,.45rem) clamp(1.4rem,6vw,2rem);}
  #catalog-modal .similar-cards{flex-direction:column;align-items:stretch;gap:.65rem;}
  #catalog-modal .similar-cards .catalog-card{flex-direction:column;align-items:stretch;gap:.65rem;padding:.65rem;border-radius:24px;width:100%;max-width:none;}
  #catalog-modal .similar-cards .catalog-card__media{flex:0 0 auto;width:100%;aspect-ratio:4/3;border-radius:20px;overflow:hidden;align-self:stretch;}
  #catalog-modal .similar-cards .catalog-card__image{border-radius:20px;width:100%;height:100%;object-fit:cover;}
  #catalog-modal .similar-cards .catalog-card__content{padding:0;gap:.45rem;min-width:0;}
  #catalog-modal .similar-cards .catalog-card__footer{flex-direction:column;align-items:stretch;gap:.45rem;}
  #catalog-modal .similar-cards .catalog-card__cta{width:100%;min-width:0;}
  .tilda-catalog{grid-template-columns:1fr;margin:0;}
  #catalog-map{margin:0 auto;width:100%;}
  .tilda-catalog .catalog-card{flex-direction:row;align-items:stretch;gap:.65rem;padding:.65rem;border-radius:24px;}
  .tilda-catalog .catalog-card__media{flex:0 0 32%;aspect-ratio:1/1;border-radius:20px;}
  .tilda-catalog .catalog-card__image,.tilda-catalog .catalog-card__placeholder{border-radius:20px;}
  .tilda-catalog .catalog-card__content{padding:.5rem 0;gap:.45rem;}
  .tilda-catalog .catalog-card__title{font-size:1rem;}
  .tilda-catalog .catalog-card__price{padding:.35rem .6rem;font-size:.85rem;}
  .tilda-catalog .catalog-card__footer{flex-direction:column;align-items:flex-start;gap:.45rem;}
  .tilda-catalog .catalog-card__cta{width:100%;}
}

/* error message */
.tilda-catalog .error{
  grid-column:1/-1;
  color:#c00;
  text-align:center;
  padding:1rem;
}

/* feature line inside product modal */
#catalog-modal .features{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  font-size:.8rem;
  color:#000;
  padding:0;
}
#catalog-modal .features span{
  display:flex;
  align-items:center;
  gap:.25rem;
}
#catalog-modal .features svg{
  width:16px;
  height:16px;
  color:#000;
  stroke:#000;
}

/* reduce spacing between heading and features inside modal */
#catalog-modal .modal-title-row + .features{
  margin-top:-0.5rem;
}

/* layout for booking summary, availability and details */
#catalog-modal .info-calendar{display:flex;flex-direction:column;gap:clamp(1rem,4vw,1.8rem);padding:0 clamp(1.25rem,4.2vw,2.4rem) clamp(1.5rem,4.2vw,2.6rem);width:100%;box-sizing:border-box;max-width:100%;}
#catalog-modal .info-calendar > *{min-width:0;}
#catalog-modal .glass-card{background:rgba(255,255,255,0.85);border-radius:28px;border:1px solid rgba(255,255,255,0.42);box-shadow:0 26px 56px rgba(17,17,17,0.16);backdrop-filter:blur(18px);padding:clamp(1.4rem,3vw,2rem);display:flex;flex-direction:column;gap:clamp(.85rem,2.2vw,1.35rem);position:relative;isolation:isolate;width:100%;box-sizing:border-box;}
#catalog-modal .booking-summary{position:relative;top:auto;align-self:stretch;z-index:auto;}

#catalog-modal .availability-card .calendar-section{display:flex;flex-direction:column;gap:clamp(.85rem,2vw,1.2rem);}
#catalog-modal .property-details{gap:clamp(1rem,2.4vw,1.6rem);}
#catalog-modal .property-details .modal-info p{line-height:1.55;color:#43464d;}
#catalog-modal .property-details .modal-map{border-radius:24px;overflow:hidden;min-height:260px;box-shadow:0 18px 42px rgba(17,17,17,0.18);}
#catalog-modal .modal-map--empty{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(255,224,188,0.92) 0%,rgba(255,239,210,0.92) 100%);border:1px dashed rgba(243,175,61,0.45);box-shadow:none;height:auto;min-height:260px;padding:1.5rem;border-radius:24px;color:#8a4d04;text-align:center;}
#catalog-modal .modal-map__empty{margin:0;font-size:1rem;line-height:1.45;max-width:22rem;}
#catalog-modal .booking-summary::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 140% at 10% 12%,rgba(243,175,61,0.22) 0%,rgba(255,255,255,0) 60%);pointer-events:none;mix-blend-mode:screen;opacity:.9;z-index:-1;}
#catalog-modal .booking-summary__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;}
#catalog-modal .booking-summary__label{text-transform:uppercase;font-size:.78rem;letter-spacing:.12em;color:#757a84;font-weight:700;}
#catalog-modal .booking-summary__price{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:999px;background:linear-gradient(135deg,rgba(243,175,61,0.2) 0%,rgba(243,175,61,0.32) 100%);border:1px solid rgba(243,175,61,0.28);box-shadow:0 14px 32px rgba(243,175,61,0.28);font-size:1.1rem;font-weight:700;color:#9d5204;white-space:nowrap;}
#catalog-modal .booking-summary__price::before{content:"";width:8px;height:8px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffe39d 0%,#f3af3d 60%,#de7f12 100%);box-shadow:0 0 8px rgba(243,175,61,0.4);}
#catalog-modal .booking-summary__rating{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;}
#catalog-modal .booking-summary__stars{display:inline-flex;gap:.3rem;color:#f3af3d;font-size:1.1rem;text-shadow:0 6px 12px rgba(243,175,61,0.25);}
#catalog-modal .booking-summary__score{font-weight:600;color:#4a4f58;font-size:.95rem;}
#catalog-modal .booking-summary__quick{display:flex;flex-direction:column;gap:.55rem;}
#catalog-modal .booking-summary__quick-title{font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#777d86;}
#catalog-modal .booking-summary__quick-actions{display:flex;flex-wrap:wrap;gap:.6rem;}
#catalog-modal .booking-summary__chip{border:none;border-radius:16px;padding:.55rem 1.1rem;background:rgba(33,36,44,0.06);color:#2f2f33;font-weight:600;font-size:.92rem;cursor:pointer;transition:background .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;box-shadow:0 8px 18px rgba(17,17,17,0.08);}
#catalog-modal .booking-summary__chip:hover,#catalog-modal .booking-summary__chip:focus-visible{background:rgba(243,175,61,0.2);color:#8a4d04;box-shadow:0 14px 28px rgba(243,175,61,0.25);outline:none;transform:translateY(-1px);}
#catalog-modal .booking-summary__chip:active{transform:scale(.97);}
#catalog-modal .booking-summary__cta{margin-top:auto;border:none;border-radius:18px;padding:.85rem 1.5rem;font-weight:700;font-size:1.05rem;background:var(--catalog-button-bg);color:var(--catalog-button-text);box-shadow:0 20px 42px rgba(243,175,61,0.4);cursor:pointer;transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background-color .25s ease;}
#catalog-modal .booking-summary__cta:hover,#catalog-modal .booking-summary__cta:focus-visible{transform:translateY(-2px);box-shadow:0 28px 56px rgba(243,175,61,0.45);outline:none;background:var(--catalog-button-bg-hover);}
#catalog-modal .booking-summary__cta:active{transform:scale(.98);}
#catalog-modal .availability-card__header{display:flex;flex-direction:column;gap:.6rem;align-items:flex-start;}
#catalog-modal .availability-card__title{font-weight:700;font-size:1.05rem;color:#2d2f35;}
#catalog-modal .availability-card__cta{align-self:stretch;width:100%;border-radius:18px;border:none;background:var(--catalog-button-bg);color:var(--catalog-button-text);font-weight:600;padding:.65rem 1.2rem;cursor:pointer;transition:transform .24s var(--catalog-ease-out),box-shadow .24s var(--catalog-ease-out),background .24s ease,color .24s ease;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.3;white-space:normal;max-width:100%;box-sizing:border-box;}
#catalog-modal .availability-card__cta:hover,#catalog-modal .availability-card__cta:focus-visible{background:var(--catalog-button-bg-hover);color:var(--catalog-button-text);box-shadow:0 16px 34px rgba(243,175,61,0.3);transform:translateY(-1px);outline:none;}
#catalog-modal .availability-card__cta:disabled{cursor:not-allowed;opacity:.6;box-shadow:none;transform:none;}

@media (min-width:901px){
  #catalog-modal .availability-card__cta{
    align-self:flex-start;
    display:inline-flex;
    width:auto;
  }
}
#catalog-modal .availability-card__legend{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.85rem;color:#5c6068;align-items:center;}
#catalog-modal .legend-item{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:14px;background:rgba(33,36,44,0.05);font-weight:600;letter-spacing:.01em;}
#catalog-modal .legend-item--busy{background:rgba(192,58,43,0.14);color:#a22d20;}
#catalog-modal .legend-note{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:14px;background:rgba(33,36,44,0.04);font-weight:600;letter-spacing:.01em;color:#5c6068;}
#catalog-modal .legend-dot{width:12px;height:12px;border-radius:50%;background:currentColor;box-shadow:0 0 10px currentColor;display:inline-block;}
#catalog-modal .availability-card__empty{margin:0;font-size:.95rem;color:#666a73;}
.star-rating{display:inline-flex;gap:2px;}
.star-rating .star{color:var(--color-orange,#f3af3d);font-size:1rem;}
.star-rating .star.empty{color:#ddd;}
#catalog-modal .category-ratings{margin-top:1rem;display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;}
#catalog-modal .reviews-block{margin-top:1rem;font-size:.9rem;}

@media (min-width:1100px){
  #catalog-modal .info-calendar{display:grid;grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);grid-template-areas:"summary availability" "summary details";gap:clamp(1.2rem,3vw,2.2rem);padding:0 clamp(1.6rem,4vw,3rem) clamp(1.6rem,4vw,3rem);align-items:start;}
  #catalog-modal .booking-summary{grid-area:summary;position:sticky;top:clamp(1.5rem,5vw,3.25rem);align-self:start;z-index:5;}
  #catalog-modal .availability-card{grid-area:availability;}
  #catalog-modal .property-details{grid-area:details;}
}

#catalog-modal .back-btn{
  position:absolute;
  top:clamp(.85rem,2vw,1.2rem);
  left:clamp(.85rem,2vw,1.2rem);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:52px;
  height:52px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.28);
  background:rgba(24,26,32,0.58);
  color:#fff;
  font-size:1.5rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 22px 46px rgba(0,0,0,0.32);
  backdrop-filter:blur(12px);
  transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease,color .25s ease;
  z-index:3;
}

#catalog-modal .back-btn:hover,
#catalog-modal .back-btn:focus-visible{
  background:rgba(16,17,22,0.78);
  color:#fff;
  box-shadow:0 28px 58px rgba(0,0,0,0.38);
  transform:translateY(-1px);
  outline:none;
}

#catalog-modal .back-btn:active{
  transform:translateY(0);
  box-shadow:0 16px 32px rgba(0,0,0,0.32);
}

#catalog-modal .similar-section{
  padding:0 2.4rem 2.4rem;
}
#catalog-modal .similar-section h4{
  margin:0 0 .5rem;
}
#catalog-modal .similar-cards{
  display:flex;
  gap:0.75rem;
  flex-wrap:wrap;
}
#catalog-modal .similar-cards .catalog-card{ 
  flex:1 1 260px;
  max-width:calc(50% - 0.75rem);
}
#catalog-modal .similar-cards .catalog-card__media{
  aspect-ratio:3/2;
  border-radius:18px;
  overflow:hidden;
}
#catalog-modal .similar-cards .catalog-card__image{
  border-radius:18px;
}
#catalog-modal .similar-cards .catalog-card__content{
  padding:.85rem 1rem;
  gap:.55rem;
}
#catalog-modal .similar-cards .catalog-card__footer{
  justify-content:flex-start;
  gap:.6rem;
}
#catalog-modal .similar-cards .catalog-card__cta{
  padding:.45rem 1rem;
}

.favorites-indicator{
  position:fixed;
  bottom:20px;
  right:20px;
  width:58px;
  height:58px;
  min-width:58px;
  min-height:58px;
  aspect-ratio:1/1;
  background:var(--catalog-button-bg);
  color:var(--catalog-button-text);
  border:none;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  line-height:1;
  cursor:pointer;
  z-index:1100;
  box-shadow:0 18px 34px rgba(0,0,0,0.18);
  transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background .25s ease;
  will-change:transform;
}
.favorites-indicator.hidden{display:none;}
.favorites-indicator .count{
  position:absolute;
  top:-6px;
  right:-6px;
  min-width:20px;
  height:20px;
  padding:0 .3rem;
  background:#e7564d;
  color:#fff;
  border-radius:999px;
  font-size:.7rem;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 6px 14px rgba(231,86,77,0.35);
}
.favorites-indicator svg{
  width:22px;
  height:22px;
  display:block;
  transition:transform .25s var(--catalog-ease-out);
}
.favorites-indicator:hover{
  transform:translateY(-2px) scale(1.03);
  box-shadow:0 20px 38px rgba(0,0,0,0.22);
  background:var(--catalog-button-bg-hover);
}
.favorites-indicator:hover svg{transform:scale(1.05);}
.favorites-indicator:active{
  transform:scale(0.97);
  box-shadow:0 14px 26px rgba(0,0,0,0.2);
}
.favorites-indicator.pulse{animation:favPulse .6s var(--catalog-ease-out);}
@media (max-width:600px){
  .favorites-indicator{
    bottom:1rem;
    right:auto;
    left:1rem;
    width:52px;
    height:52px;
    min-width:52px;
    min-height:52px;
  }
  .favorites-indicator .count{
    min-width:18px;
    height:18px;
    font-size:.64rem;
  }
}

.favorites-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.6);display:none;align-items:center;justify-content:center;z-index:1100;font-family:'Nunito',sans-serif;padding:1.5rem;box-sizing:border-box;}
.favorites-modal.show{display:flex;}
.favorites-modal .fav-dialog{position:relative;display:flex;flex-direction:column;background:#fff;border-radius:26px;box-shadow:0 32px 60px rgba(17,17,17,0.18);width:min(640px,100%);max-height:min(90vh,760px);overflow:hidden;border:1px solid rgba(17,17,17,0.08);}
.favorites-modal .fav-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.5rem 1.75rem;background:#fff;color:#1f2a44;border-bottom:1px solid rgba(17,17,17,0.08);}
.favorites-modal .fav-header-group{display:flex;flex-direction:column;gap:.35rem;max-width:calc(100% - 60px);}
.favorites-modal .fav-title{margin:0;font-size:1.45rem;font-weight:700;letter-spacing:.01em;color:#1f2a44;}
.favorites-modal .fav-counter{display:inline-flex;align-items:center;gap:.4rem;font-size:.92rem;font-weight:600;padding:.35rem .85rem;border-radius:999px;background:rgba(243,175,61,0.16);color:#d9861a;border:1px solid rgba(243,175,61,0.22);}
.favorites-modal .fav-close{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;border:none;background:rgba(17,17,17,0.06);color:#435072;font-size:1.6rem;cursor:pointer;transition:transform .25s var(--catalog-ease-out),background .25s ease,box-shadow .25s ease,color .25s ease;}
.favorites-modal .fav-close:hover,.favorites-modal .fav-close:focus-visible{background:rgba(17,17,17,0.1);transform:scale(1.05);box-shadow:0 6px 18px rgba(17,17,17,0.12);outline:none;color:#1f2a44;}
.favorites-modal .fav-close:active{transform:scale(.92);}
.favorites-modal .fav-body{padding:1.75rem 2rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto;flex:1 1 auto;}
.favorites-modal .fav-hint{margin:0;font-size:.98rem;line-height:1.45;color:#435072;}
.favorites-modal [hidden]{display:none!important;}
.favorites-modal .fav-list{display:flex;flex-direction:column;gap:1rem;}
.favorites-modal .fav-list > .fav-card{flex:0 0 auto;}
.favorites-modal .fav-empty{margin:0;text-align:center;font-size:.98rem;line-height:1.5;color:#6f6f77;padding:2.25rem 1.75rem;background:#f7f8fb;border:1px dashed rgba(111,111,119,0.35);border-radius:18px;}
.favorites-modal .fav-footer{display:flex;flex-wrap:wrap;gap:.75rem;padding:1.35rem 2rem 1.75rem;border-top:1px solid rgba(17,17,17,0.08);background:#fff;}
.favorites-modal .fav-footer button{flex:1 1 200px;font-weight:600;font-size:1rem;transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),background-color .25s ease,color .25s ease;}
.favorites-modal .fav-clear{border-radius:999px;border:1px solid rgba(192,58,43,0.35);background:rgba(192,58,43,0.08);color:#c03a2b;padding:.75rem 1.5rem;cursor:pointer;}
.favorites-modal .fav-clear:hover:not(:disabled),.favorites-modal .fav-clear:focus-visible:not(:disabled){background:rgba(192,58,43,0.16);box-shadow:0 10px 24px rgba(192,58,43,0.18);outline:none;}
.favorites-modal .fav-clear:active:not(:disabled){transform:scale(.97);}
.favorites-modal .fav-clear:disabled{cursor:not-allowed;background:rgba(192,58,43,0.06);color:rgba(192,58,43,0.45);border-color:rgba(192,58,43,0.2);box-shadow:none;}
.favorites-modal .fav-cta{border-radius:999px;border:none;background:var(--catalog-button-bg);color:var(--catalog-button-text);padding:.85rem 1.75rem;cursor:pointer;box-shadow:0 16px 32px rgba(241,138,47,0.35);}
.favorites-modal .fav-cta:hover:not(:disabled),.favorites-modal .fav-cta:focus-visible:not(:disabled){transform:translateY(-2px);box-shadow:0 22px 38px rgba(243,175,61,0.42);outline:none;background:var(--catalog-button-bg-hover);}
.favorites-modal .fav-cta:active:not(:disabled){transform:scale(.98);}
.favorites-modal .fav-cta:disabled{cursor:not-allowed;background:#d7d9dd;color:#8a8d93;box-shadow:none;}
.favorites-modal .fav-card{position:relative;display:flex;gap:1.25rem;padding:1.35rem 1.25rem 1.1rem;border-radius:20px;border:1px solid rgba(17,17,17,0.06);background:#fff;box-shadow:0 14px 32px rgba(17,17,17,0.12);cursor:pointer;transition:transform .25s var(--catalog-ease-out),box-shadow .25s var(--catalog-ease-out),border-color .25s ease;overflow:hidden;}
.favorites-modal .fav-card:hover{transform:translateY(-3px);box-shadow:0 22px 44px rgba(17,17,17,0.15);border-color:rgba(243,175,61,0.32);}
.favorites-modal .fav-card:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(243,175,61,0.28),0 22px 44px rgba(17,17,17,0.15);}
.favorites-modal .fav-card__media{flex:0 0 148px;height:108px;border-radius:16px;overflow:hidden;position:relative;background:#f1f2f4;box-shadow:inset 0 0 0 1px rgba(17,17,17,0.08);}
.favorites-modal .fav-card__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s var(--catalog-ease-out);}
.favorites-modal .fav-card:hover .fav-card__media img{transform:scale(1.05);}
.favorites-modal .fav-card__content{flex:1;display:flex;flex-direction:column;gap:.6rem;min-width:0;}
.favorites-modal .fav-card__header{display:flex;flex-direction:column;align-items:flex-start;gap:.4rem;padding-right:2.75rem;}
.favorites-modal .fav-card__title{margin:0;font-size:1.1rem;font-weight:700;color:#1f2a44;text-transform:capitalize;line-height:1.3;flex:1 1 auto;}
.favorites-modal .fav-card__price{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:14px;background:rgba(243,175,61,0.16);color:#d9861a;font-weight:600;font-size:.95rem;white-space:nowrap;box-shadow:none;margin-top:auto;align-self:flex-end;}
.favorites-modal .fav-card__meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem;}
.favorites-modal .fav-card__meta-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;color:#36405f;padding:.35rem .7rem;border-radius:999px;background:rgba(67,80,114,0.08);transition:background .2s ease,color .2s ease;}
.favorites-modal .fav-card__meta-item .fav-card__icon{width:16px;height:16px;color:#1f1f1f;stroke:currentColor;opacity:.85;}
.favorites-modal .fav-card__meta-item--city{background:rgba(67,80,114,0.08);color:#36405f;}
.favorites-modal .fav-card__meta-item--district{background:rgba(67,80,114,0.08);color:#36405f;}
.favorites-modal .fav-card__meta-item--complex{background:rgba(67,80,114,0.08);color:#36405f;}
.favorites-modal .fav-card__meta-item:hover{background:rgba(67,80,114,0.12);color:#36405f;}
.favorites-modal .fav-card__remove{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,0.92);box-shadow:0 10px 22px rgba(17,17,17,0.18);display:flex;align-items:center;justify-content:center;color:#c03a2b;font-size:1.35rem;cursor:pointer;transition:transform .2s var(--catalog-ease-out),box-shadow .2s ease,background .2s ease,color .2s ease;z-index:2;}
.favorites-modal .fav-card__remove:hover,.favorites-modal .fav-card__remove:focus-visible{transform:scale(1.05);background:#fff;box-shadow:0 14px 30px rgba(192,58,43,0.35);color:#a22d20;outline:none;}
.favorites-modal .fav-card__remove:active{transform:scale(.92);}
.favorites-modal .fav-card__remove span{font-size:1.35rem;line-height:1;}

@media (max-width:768px){
  .favorites-modal{align-items:flex-end;padding:0;}
  .favorites-modal .fav-content{
    width:100%;
    max-width:none;
    max-height:calc(100vh - 12px);
    border-radius:32px 32px 0 0;
    box-shadow:0 -12px 36px rgba(17,17,17,0.24);
    margin:0;
    display:flex;
    flex-direction:column;
    min-height:0;
  }
  .favorites-modal .fav-header{padding:1.35rem 1.5rem 1.1rem;}
  .favorites-modal .fav-body{
    padding:1.1rem 1.5rem .75rem;
    gap:.85rem;
    flex:1 1 auto;
    display:flex;
    flex-direction:column;
    overflow:hidden;
    min-height:0;
  }
  .favorites-modal .fav-hint{font-size:.95rem;}
  .favorites-modal .fav-list{
    flex:1 1 auto;
    min-height:0;
    overflow-y:auto;
    margin:0;
    margin-right:-.5rem;
    padding-right:.5rem;
    padding-bottom:calc(1rem + env(safe-area-inset-bottom));
    overscroll-behavior:contain;
    scrollbar-width:thin;
  }
  .favorites-modal .fav-list::-webkit-scrollbar{width:6px;}
  .favorites-modal .fav-list::-webkit-scrollbar-thumb{background:rgba(31,31,31,0.2);border-radius:999px;}
  .favorites-modal .fav-empty{
    flex:1 1 auto;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .favorites-modal .fav-actions{
    position:sticky;
    bottom:0;
    left:0;
    right:0;
    margin-top:0;
    padding:1rem 1.5rem calc(1.1rem + env(safe-area-inset-bottom));
    border-top:1px solid rgba(17,17,17,0.08);
    box-shadow:0 -18px 32px rgba(17,17,17,0.16);
    background:#fff;
    z-index:5;
  }
  .favorites-modal .fav-actions button{flex:1 1 auto;}
  .favorites-modal .fav-card__price{align-self:flex-start;}
}
@media (max-width:599px){
  .favorites-modal .fav-card{flex-direction:column;gap:.85rem;padding:1.35rem 1rem 1rem;border-radius:20px;}
  .favorites-modal .fav-card__media{flex:0 0 auto;width:100%;height:180px;border-radius:18px;}
  .favorites-modal .fav-card__remove{top:12px;right:12px;}
}
@media (max-width:600px){
  #catalog-modal .modal-hero__header{grid-template-columns:minmax(0,1fr);gap:.6rem;justify-items:stretch;}
  #catalog-modal .modal-hero__header-actions{justify-self:start;align-self:start;}
  #catalog-modal .similar-cards{flex-direction:column;}
  #catalog-modal .similar-cards .catalog-card{max-width:100%;flex:1 1 100%;}
}
.selected-objects{font-size:.9rem;margin:.5rem 0;padding:.75rem 1rem;border-radius:14px;background:rgba(243,175,61,0.14);color:#744d0f;font-weight:600;box-shadow:0 12px 24px rgba(243,175,61,0.18);}

.catalog-booking-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,rgba(33,36,44,0.78) 0%,rgba(33,36,44,0.74) 36%,rgba(243,175,61,0.25) 100%);backdrop-filter:blur(8px);z-index:1200;padding:2rem;box-sizing:border-box;overflow:auto;font-family:'Nunito',sans-serif;}
.booking-dialog{width:100%;max-width:420px;background:var(--catalog-card-surface);border-radius:24px;border:1px solid var(--catalog-card-border);box-shadow:var(--catalog-card-shadow);display:flex;flex-direction:column;max-height:100%;overflow:hidden;position:relative;}
.booking-dialog::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at top right,rgba(243,175,61,0.16) 0%,rgba(243,175,61,0) 55%);mix-blend-mode:multiply;}
.booking-header{position:relative;display:flex;align-items:flex-start;gap:1rem;padding:1.85rem 1.85rem 1.15rem;background:var(--catalog-amber-gradient-header);border-bottom:1px solid rgba(255,255,255,0.35);z-index:1;color:#fff;}
.booking-header-group{flex:1;display:flex;flex-direction:column;gap:.35rem;min-width:0;}
.booking-title{font-size:1.55rem;line-height:1.2;margin:0;color:inherit;font-weight:700;}
.booking-hint{margin:0;color:rgba(255,255,255,0.92);font-size:.97rem;line-height:1.45;}
.booking-close{flex:0 0 auto;background:rgba(255,255,255,0.92);border:1px solid rgba(255,255,255,0.65);border-radius:50%;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;cursor:pointer;color:#a04e08;box-shadow:0 12px 28px rgba(241,138,47,0.28);transition:background .2s var(--catalog-ease-out),color .2s var(--catalog-ease-out),transform .2s var(--catalog-ease-out),box-shadow .2s var(--catalog-ease-out);}
.booking-close:hover,.booking-close:focus-visible{background:#fff;color:#863c02;box-shadow:0 16px 32px rgba(241,138,47,0.32);outline:none;}
.booking-close:active{transform:scale(0.92);}
.booking-body{padding:0 1.85rem 1.85rem;display:flex;flex-direction:column;gap:1.05rem;overflow:auto;position:relative;z-index:1;}
.booking-field{display:flex;flex-direction:column;gap:.45rem;}
.booking-field label{font-size:.95rem;color:#393939;font-weight:600;letter-spacing:.01em;}
.booking-field input,.booking-field textarea{width:100%;padding:.85rem 1rem;border:1px solid rgba(17,17,17,0.1);border-radius:16px;font-family:'Nunito',sans-serif;font-size:1rem;line-height:1.45;background:rgba(255,255,255,0.92);box-shadow:0 12px 28px rgba(17,17,17,0.08);transition:border-color .2s var(--catalog-ease-out),box-shadow .2s var(--catalog-ease-out),background .2s ease;box-sizing:border-box;}
.booking-field input:focus,.booking-field textarea:focus{border-color:rgba(243,175,61,0.55);box-shadow:0 0 0 3px rgba(243,175,61,0.22),0 14px 32px rgba(243,175,61,0.18);background:#fff;outline:none;}
.booking-field input[type="date"]{padding-right:.5rem;}
.booking-field textarea{min-height:112px;resize:vertical;}
.booking-field input::placeholder,.booking-field textarea::placeholder{color:#8a8a8a;}
.booking-footer{position:relative;padding:1.25rem 1.85rem 1.85rem;border-top:1px solid rgba(17,17,17,0.06);display:flex;flex-direction:column;gap:.85rem;background:linear-gradient(180deg,rgba(255,255,255,0.86) 0%,rgba(255,247,235,0.92) 100%);box-shadow:0 -18px 32px rgba(17,17,17,0.08);z-index:1;}
.booking-footer .book-btn{width:100%;box-sizing:border-box;display:flex;align-items:center;justify-content:center;}

@media (max-width:767px){
  .catalog-booking-overlay{padding:1.5rem 1rem;}
  .booking-dialog{border-radius:20px;}
  .booking-header{padding:1.65rem 1.4rem 1rem;}
  .booking-body{padding:0 1.4rem 1.5rem;}
  .booking-footer{padding:1.1rem 1.4rem 1.4rem;}
}

@media (max-width:479px){
  .booking-dialog{border-radius:18px;}
  .booking-title{font-size:1.35rem;}
  .booking-hint{font-size:.9rem;}
  .booking-close{width:34px;height:34px;font-size:1.35rem;}
  .booking-body{gap:.9rem;}
}

@media (prefers-reduced-motion:reduce){
  .view-entering,
  .view-leaving,
  .favorites-indicator.pulse,
  .icon-btn.fav.fav-animate-add{animation:none!important;}
  .shimmer{animation:none!important;background-image:none;background-color:rgba(240,240,240,0.9);}
  .view-toggle .view-btn,
  .favorites-indicator,
  .icon-btn{transition:none!important;}
}

/* cluster popup */
.cluster-popup{position:relative;width:260px;}
.cluster-card-container{width:100%;}
.cluster-nav{position:absolute;top:45%;background:none;border:none;font-size:1.2rem;cursor:pointer;}
.cluster-nav.prev{left:0;}
.cluster-nav.next{right:0;}
.cluster-popup .catalog-card{box-shadow:none;}
