*{box-sizing:border-box;margin:0;padding:0}
body{background:#EDE6DC;font-family:'Montserrat',sans-serif;padding:32px 16px}
.wrap{max-width:1100px;margin:0 auto}

/* ── SEARCH BAR — palette LDD chiara ── */
.bar{
    background:#FAF8F5;
    border:1.5px solid #CB9C73;
    border-radius:16px;
    padding:20px 24px;
    display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;
    margin-bottom:36px;
    box-shadow:0 4px 20px rgba(26,24,23,.08);
}
.f{display:flex;flex-direction:column;gap:7px}
.flabel{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#8A8A8A}
.f-dest{flex:1;min-width:150px}
.f-dates{flex:2;min-width:240px;position:relative}
.f-guests{flex:2;min-width:210px}
.f-btn{flex:0;align-self:flex-end}

/* SELECT */
.fsel{
    background:#F2EDE6;
    border:1.5px solid #CB9C73;
    border-radius:9px;
    padding:11px 13px;
    font-size:13px;font-family:'Montserrat',sans-serif;
    color:#1A1817;
    outline:none;width:100%;
    transition:border-color .2s;cursor:pointer;
}
.fsel:focus{border-color:#CB9C73}
.fsel option{background:#FAF8F5;color:#1A1817}

/* DATE TRIGGER */
.dtrig{
    background:#F2EDE6;
    border:1.5px solid #CB9C73;
    border-radius:9px;
    padding:11px 13px;cursor:pointer;
    display:flex;align-items:center;gap:10px;
    user-select:none;transition:border-color .2s,background .2s;width:100%;
}
.dtrig:hover,.dtrig.open{border-color:#CB9C73;background:#EDE6DC}
.dsep{width:1px;height:26px;background:#E8E0D8;flex-shrink:0}
.dslot{flex:1;min-width:0}
.dslot-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#8A8A8A;margin-bottom:2px}
.dslot-val{font-size:13px;font-weight:500;color:#1A1817;white-space:nowrap}
.dslot-val.ph{color:#8A8A8A}
.dnights{font-size:10px;font-weight:600;color:#CB9C73;flex-shrink:0;white-space:nowrap}
.dicon{color:#8A8A8A;flex-shrink:0}

/* CALENDARIO */
/* ── Calendario ──────────────────────────────────────────────────────────── */
.cal{
  display:none;
  position:fixed;
  z-index:9999;
  background:#FAF8F5;
  border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  border:1px solid #E8E0D8;
  padding:20px 22px 16px;
  width:604px;
  box-sizing:border-box;
}
.cal.open{display:block}
.cal-tip{text-align:center;font-size:11px;color:#5A5A5A;margin-bottom:16px;font-weight:500}
.cal-tip strong{color:#CB9C73}
.months{display:flex;gap:32px;flex-wrap:nowrap}
.month{width:264px;flex-shrink:0;min-width:0}
.mhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mname{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:500;color:#1A1817}
.mnav{
  width:32px;height:32px;border-radius:50%;
  border:1px solid #E8E0D8;background:transparent;
  cursor:pointer;font-size:18px;color:#5A5A5A;
  display:flex;align-items:center;justify-content:center;
  line-height:1;transition:all .15s;padding:0;
  flex-shrink:0;
  /* touch target minimo 44px tramite padding trasparente */
  -webkit-tap-highlight-color:transparent;
}
.mnav:hover:not(:disabled){background:#F2EDE6;border-color:#CB9C73;color:#1A1817}
.mnav:disabled{opacity:.3;cursor:default;pointer-events:none}
.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;width:100%}
.dow{
  height:28px;
  display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#8A8A8A;
}
.day{
  aspect-ratio:1;
  border-radius:50%;border:none;background:transparent;
  font-family:'Montserrat',sans-serif;font-size:12px;font-weight:500;color:#1A1817;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .1s,color .1s;position:relative;padding:0;
  -webkit-tap-highlight-color:transparent;
}
.day.off{visibility:hidden;pointer-events:none}
.day.dis{color:#ccc;pointer-events:none}
.day.today::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;background:#CB9C73;border-radius:50%}
.day:hover:not(.dis):not(.off){background:#F2EDE6}
.day.s,.day.e{background:#1A1817!important;color:#FAF8F5!important;border-radius:50%!important}
.day.rng{background:rgba(203,156,115,.2);border-radius:0;color:#1A1817}
.day.rng.rs{border-radius:50% 0 0 50%}
.day.rng.re{border-radius:0 50% 50% 0}
.day.hrng{background:rgba(203,156,115,.1);border-radius:0}
.day.hre{background:rgba(203,156,115,.18)!important;border-radius:0 50% 50% 0}
.cal-foot{display:flex;align-items:center;justify-content:space-between;
  margin-top:16px;padding-top:14px;border-top:1px solid #E8E0D8}
.cal-sum{font-size:11px;color:#5A5A5A}
.cal-sum strong{color:#1A1817;font-weight:700}
.cal-close-mobile{display:none}
.btn-clr{font-size:11px;font-weight:600;color:#5A5A5A;background:none;border:none;
  cursor:pointer;padding:7px 12px;border-radius:7px;transition:background .15s}
.btn-clr:hover{background:#F2EDE6}

/* OSPITI */
.guests{background:#F2EDE6;border:1.5px solid #CB9C73;
  border-radius:9px;padding:10px 14px;display:flex;flex-direction:column;gap:9px}
.grow{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#1A1817}
.grow small{font-size:10px;color:#8A8A8A;margin-left:4px}
.gctr{display:flex;align-items:center;gap:11px}
.gbtn{width:28px;height:28px;border-radius:50%;border:1.5px solid #E8E0D8;
  background:#FAF8F5;color:#1A1817;font-size:18px;cursor:pointer;line-height:1;padding:0;
  display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s}
.gbtn:hover{background:#CB9C73;border-color:#CB9C73;color:#fff}
.gval{font-size:14px;font-weight:700;color:#1A1817;min-width:20px;text-align:center}

/* SEARCH BTN */
.sbtn{background:#CB9C73;color:#fff;border:none;border-radius:9px;padding:12px 26px;
  font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:8px;white-space:nowrap;transition:background .2s}
.sbtn:hover{background:#A87A52}
.sbtn:disabled{opacity:.5;cursor:not-allowed}

/* RISULTATI */
.status-box{text-align:center;padding:28px;font-size:13px;color:#5A5A5A;display:flex;align-items:center;justify-content:center;gap:10px}
.status-box.ld::before{content:'';width:20px;height:20px;border:2px solid #E8E0D8;
  border-top-color:#CB9C73;border-radius:50%;animation:sp .7s linear infinite;flex-shrink:0}
.status-box.err{color:#c0392b}
@keyframes sp{to{transform:rotate(360deg)}}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.rhdr{font-size:13px;color:#5A5A5A;grid-column:1/-1;padding-bottom:14px;border-bottom:1px solid #E8E0D8;margin-bottom:4px}
.rhdr strong{color:#1A1817;font-weight:700}
/* CARD */
.card{background:#FAF8F5;border-radius:14px;overflow:hidden;border:1px solid #E8E0D8;
  box-shadow:0 2px 10px rgba(0,0,0,.07);transition:transform .3s,box-shadow .3s;
  animation:ci .45s ease both}
@keyframes ci{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.card:nth-child(2){animation-delay:.08s}.card:nth-child(3){animation-delay:.16s}.card:nth-child(4){animation-delay:.24s}
.card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(0,0,0,.13)}
.card-img{position:relative;aspect-ratio:16/9;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block}
.card:hover .card-img img{transform:scale(1.05)}
.badge{position:absolute;top:11px;left:11px;background:rgba(26,24,23,.75);backdrop-filter:blur(6px);
  color:#fff;font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px}
.card-body{padding:15px 17px 17px}
.card-title{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;line-height:1.3;
  color:#1A1817;text-decoration:none;display:block;margin-bottom:12px;transition:color .2s}
.card-title:hover{color:#A87A52}
.card-subtitle{font-size:11px;font-weight:700;color:#A8A09A;margin:3px 0 10px;line-height:1.3;letter-spacing:.09em;text-transform:uppercase}
.feats{display:flex;border-top:1px solid #E8E0D8;border-bottom:1px solid #E8E0D8;padding:9px 0;margin-bottom:11px}
.feat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;border-right:1px solid #E8E0D8;padding:0 4px}
.feat:last-child{border-right:none}
.fv{font-size:12px;font-weight:700;color:#1A1817}
.fl{font-size:9px;color:#5A5A5A;text-transform:uppercase;letter-spacing:.05em}
.card-sum{font-size:11.5px;line-height:1.65;color:#5A5A5A;margin-bottom:13px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{display:flex;flex-direction:column;align-items:flex-start;padding-top:11px;border-top:1px solid #E8E0D8;gap:8px}
.price-from{font-size:9px;font-weight:500;color:#5A5A5A;text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px}
.price{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;color:#1A1817;line-height:1}
.price span{font-size:11px;color:#5A5A5A;font-family:'Montserrat',sans-serif}
.price-tot{font-size:10px;color:#5A5A5A;margin-top:3px;display:block;width:100%}
.cbtns{display:flex;gap:7px;flex-shrink:0}
.cbtn{padding:8px 14px;border-radius:7px;font-size:10px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;text-decoration:none;border:1.5px solid;cursor:pointer;
  transition:background .15s,border-color .15s;white-space:nowrap}
.cbtn-d{background:transparent;color:#1A1817;border-color:#1A1817}
.cbtn-d:hover{background:#F2EDE6}
.cbtn-b{background:#1A1817;color:#fff;border-color:#1A1817}
.cbtn-b:hover{background:#A87A52;border-color:#A87A52}
.no-res{text-align:center;padding:48px 24px;background:#F2EDE6;border-radius:14px;grid-column:1/-1}
.no-res h3{font-family:'Cormorant Garamond',serif;font-size:22px;color:#1A1817;margin-bottom:8px}
.no-res p{font-size:12px;color:#5A5A5A;line-height:1.7}

/* ── Sezione descrittiva homepage ───────────────────────────────────────── */
.ldd-about-section{
  margin-top:32px;
  padding:20px 24px;
  border:1px solid #E8E0D8;
  border-radius:14px;
  background:#FAF8F5;
}
.ldd-about-title{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;font-weight:500;color:#1A1817;
  margin:0 0 10px;line-height:1.3;
}
.ldd-about-body p{
  font-size:12px;line-height:1.7;color:#8A8A8A;
  margin:0 0 6px;
}
.ldd-about-body p:last-child{margin-bottom:0}
.ldd-about-body em{font-style:italic}

@media(max-width:660px){
  /* Mobile: overlay a schermo intero */
  .cal{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    bottom:0 !important;
    width:100% !important;
    height:100% !important;
    border-radius:0 !important;
    border:none !important;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:20px 16px 32px !important;
    display:none;
  }
  .cal.open{display:block}
  .months{flex-direction:column;gap:20px}
  .month{width:100%;min-width:0}
  .grid{grid-template-columns:repeat(7,1fr)}
  /* Bottone chiudi visibile su mobile */
  .cal-close-mobile{
    display:flex;
    justify-content:flex-end;
    margin-bottom:12px;
  }
  .cal-close-btn{
    background:none;border:none;font-size:22px;color:#5A5A5A;
    cursor:pointer;padding:8px;line-height:1;
  }
  .bar{flex-direction:column;padding:16px}
  .f-dest,.f-dates,.f-guests,.f-btn{width:100%;min-width:0;flex:none}
  .fsel,.dtrig,.guests{width:100%}
  .sbtn{width:100%;justify-content:center}
  .cards{grid-template-columns:1fr}
}

/* ── NEARBY ── */
/* ── LDD Nearby Places ───────────────────────────────────────────────────── */

.ldd-nearby {
  font-family: 'Montserrat', sans-serif;
  margin: 32px 0;
}

.ldd-nearby__title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 500;
  color: #1A1817;
  margin-bottom: 16px;
}

/* ── Tab buttons ─────────────────────────────────────────────────────────── */

.ldd-nearby__tab-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.ldd-nearby__tab-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 24px;
  border: 1.5px solid #E8E0D8;
  background: #FAF8F5;
  color: #5A5A5A;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.ldd-nearby__tab-btn:hover {
  border-color: #CB9C73;
  color: #1A1817;
  background: #F2EDE6;
}

.ldd-nearby__tab-btn.active {
  background: #1A1817;
  border-color: #1A1817;
  color: #FAF8F5;
}

.ldd-nearby__tab-emoji {
  font-size: 14px;
  line-height: 1;
}

.ldd-nearby__tab-count {
  background: rgba(255,255,255,0.2);
  border-radius: 10px;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 700;
}

.ldd-nearby__tab-btn:not(.active) .ldd-nearby__tab-count {
  background: #E8E0D8;
  color: #5A5A5A;
}

/* ── Panels ──────────────────────────────────────────────────────────────── */

.ldd-nearby__panel {
  display: none;
  animation: nearby-in 0.25s ease;
}

.ldd-nearby__panel.active {
  display: block;
}

@keyframes nearby-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── List ────────────────────────────────────────────────────────────────── */

.ldd-nearby__list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 12px;
}

.ldd-nearby__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 10px;
  background: #FAF8F5;
  border: 1px solid #E8E0D8;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
}

.ldd-nearby__item:hover {
  background: #F2EDE6;
  border-color: #CB9C73;
  transform: translateX(3px);
}

.ldd-nearby__item-main {
  flex: 1;
  min-width: 0;
}

.ldd-nearby__item-name {
  font-size: 13px;
  font-weight: 600;
  color: #1A1817;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}

.ldd-nearby__item-address {
  font-size: 11px;
  color: #5A5A5A;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ldd-nearby__item-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
}

.ldd-nearby__item-rating {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 12px;
  font-weight: 600;
  color: #1A1817;
}

.ldd-nearby__item-reviews {
  font-size: 10px;
  font-weight: 400;
  color: #5A5A5A;
}

.ldd-nearby__item-dist {
  font-size: 11px;
  font-weight: 600;
  color: #CB9C73;
  background: rgba(203,156,115,0.12);
  padding: 2px 7px;
  border-radius: 10px;
}

/* ── Maps link ───────────────────────────────────────────────────────────── */

.ldd-nearby__maps-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  color: #5A5A5A;
  text-decoration: none;
  padding: 6px 0;
  transition: color 0.2s;
  letter-spacing: 0.03em;
}

.ldd-nearby__maps-link:hover {
  color: #CB9C73;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 480px) {
  .ldd-nearby__tab-btns { gap: 6px; }
  .ldd-nearby__tab-btn { font-size: 11px; padding: 7px 11px; }
  .ldd-nearby__item { flex-direction: column; align-items: flex-start; gap: 8px; }
  .ldd-nearby__item-meta { flex-direction: row; align-items: center; }
}


/* ── CARD STATS ── */
.card-stats{display:flex;gap:6px;margin-bottom:12px}
.cstat{background:#F2EDE6;border-radius:7px;padding:5px 8px;font-size:10px;
  color:#5A5A5A;font-weight:500;line-height:1.3;flex:1;text-align:center}
.cstat strong{display:block;font-size:13px;font-weight:700;color:#1A1817}
/* promo badge sull'immagine */
/* badge-promo: see full definition below */
/* badge "prenotato recentemente" */
.badge-recent{position:absolute;bottom:11px;right:11px;background:#6A8F70;
  color:#fff;font-size:10px;font-weight:500;padding:3px 9px;border-radius:20px;
  display:flex;align-items:center;gap:5px;z-index:2}
.badge-recent::before{content:'';width:6px;height:6px;background:#fff;
  border-radius:50%;animation:pulse 1.8s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ── SOLD OUT ── */
/* ── Banner last-minute ─────────────────────────────────────────────── */
.ldd-lm-banner{
    display: block;
    text-align: center;
    background: #F5F0E8;
    border: 1px solid #E0D5C5;
    border-radius: 10px;
    padding: 16px 24px;
    margin-bottom: 20px;
    font-family: 'Montserrat', sans-serif;
}
.ldd-lm-text {
    font-size: 13px;
    font-weight: 700;
    color: #6A8F70;
    line-height: 1.6;
    margin: 0 0 12px;
}

.next-avail-link {
    color: #6A8F70;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 2px;
    white-space: nowrap;
}
.next-avail-link:hover {
    color: #4e6e54;
}
.sold-out-overlay{position:absolute;inset:0;background:rgba(26,24,23,.55);
  display:flex;align-items:center;justify-content:center}
.sold-out-overlay span{background:#1A1817;color:#FAF8F5;font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;padding:7px 16px;border-radius:20px}
.card-soldout{opacity:.82}
.card-soldout .card-img img{filter:grayscale(30%)}
.sold-out-price{font-size:11px;color:#8A8A8A;font-style:normal;font-family:'Montserrat',sans-serif;word-break:break-word;line-height:1.5}
.cbtn-sold{background:transparent;color:#5A5A5A;border-color:#5A5A5A}
.cbtn-sold:hover{background:#F2EDE6}

/* ── PRENOTA ORA — colore sabbia come Cerca ── */
.cbtn-sand {
  background: #CB9C73;
  color: #fff;
  border-color: #CB9C73;
}
.cbtn-sand:hover { background: #A87A52; border-color: #A87A52; }

/* ── SHARE BUTTON ── */
.cbtn-share {
  background: transparent;
  color: #5A5A5A;
  border-color: #E8E0D8;
  padding: 8px 10px;
  font-size: 13px;
  cursor: pointer;
  flex-shrink: 0;
}
.cbtn-share:hover { background: #F2EDE6; border-color: #CB9C73; color: #1A1817; }

/* ── BADGE CITTÀ ── */
.badge-city {
    position: absolute;
    bottom: 11px;
    left: 11px;
    background: rgba(26,24,23,.72);
    backdrop-filter: blur(6px);
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    padding: 3px 9px;
    border-radius: 20px;
    letter-spacing: .03em;
    z-index: 2;
}

/* ── MAPPA ── */
.cbtn-map {
  background: transparent;
  color: #5A5A5A;
  border-color: #E8E0D8;
  padding: 8px 10px;
  font-size: 13px;
  text-decoration: none;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cbtn-map:hover { background: #F2EDE6; border-color: #6A8F70; color: #1A1817; }

/* ── PRICE BLOCK inline ── */
.price-block{display:flex;flex-direction:column;gap:1px}
.price-block .price-from{font-size:9px;font-weight:500;color:#8A8A8A;text-transform:uppercase;letter-spacing:.06em}
.price-block .price-tot{font-size:10px;color:#5A5A5A;width:100%;margin-top:2px}

/* ── RESULTS LABEL (intestazione sezione prima e dopo ricerca) ── */
/* ══════════════════════════════════════════════════════════════
   SEARCH RESULTS HEADER
   Intestazione prominente con criteri di ricerca e conteggio
══════════════════════════════════════════════════════════════ */
.results-label {
    grid-column: 1 / -1;
    width: 100%;
    margin-bottom: 28px;
    animation: srHdrIn .4s cubic-bezier(.22,1,.36,1) both;
}
@keyframes srHdrIn {
    from { opacity:0; transform:translateY(-10px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ── Riga superiore: count + reset ── */
.rl-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}
.rl-count-wrap {
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.rl-count-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 32px;
    font-weight: 500;
    color: #1A1817;
    line-height: 1;
}
.rl-count-label {
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: #5A5A5A;
    letter-spacing: .04em;
    text-transform: uppercase;
}

/* ── Chip criteri di ricerca ── */
.rl-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 16px 20px;
    background: #FAF8F5;
    border: 1.5px solid #CB9C73;
    border-radius: 14px;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(26,24,23,.08);
}
.rl-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: #F2EDE6;
    border: 1px solid #E8E0D8;
    border-radius: 20px;
    padding: 8px 16px;
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: #1A1817;
    letter-spacing: .02em;
    white-space: nowrap;
}
.rl-chip svg { color: #CB9C73; flex-shrink: 0; }
.rl-chip strong { color: #1A1817; font-weight: 700; }
.rl-chip-sep {
    width: 4px; height: 4px;
    background: #E8E0D8;
    border-radius: 50%;
    flex-shrink: 0;
}
/* "Nessuna disponibilità" fallback */
.rl-empty-note {
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    color: #8A8A8A;
    margin-left: auto;
}

/* ── Reset button (in topbar) ── */
.btn-reset {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 600;
    color: #5A5A5A;
    background: transparent;
    border: 1.5px solid #E8E0D8;
    border-radius: 20px;
    padding: 6px 14px;
    cursor: pointer;
    letter-spacing: .04em;
    transition: all .15s;
    white-space: nowrap;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.btn-reset:hover {
    background: #F2EDE6;
    border-color: #CB9C73;
    color: #1A1817;
}

@media (max-width: 660px) {
    .rl-count-num { font-size: 26px; }
    .rl-chips { gap: 6px; padding: 12px; }
    .rl-chip  { font-size: 10px; padding: 5px 10px; }
}

/* ── PROMO BADGE — varianti per tipo ── */
.badge-promo-lm {
    /* Last Minute: sfondo rosso urgente */
    background: #C0392B !important;
    animation: lm-pulse 2s ease-in-out infinite;
}
@keyframes lm-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(192,57,43,.4); }
    50%       { box-shadow: 0 0 0 6px rgba(192,57,43,0); }
}
.badge-promo-eb {
    /* Early Bird: sfondo verde scuro */
    background: #27AE60 !important;
}

/* ── PREZZI CON SCONTO ── */
.price-strike {
    text-decoration: line-through !important;
    color: #8A8A8A !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    opacity: .8;
}
.price-strike span { font-size: 10px !important; }
.price-discounted  { color: #C0392B !important; font-weight: 700 !important; }

/* Riga prezzo inline: barrato + scontato + nome promo sulla stessa riga */
.price-row-inline {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 5px;
    line-height: 1.2;
}
.price-strike-inline {
    text-decoration: line-through;
    color: #9A9A9A;
    font-size: 12px;
    font-weight: 400;
}
.price-unit { font-size: 11px; font-weight: 400; color: #5A5A5A; }
.price-est  { font-size: 10px; color: #8A8A8A; font-style: normal; }
.price-promo-name {
    font-size: 10px;
    font-weight: 600;
    color: #fff;
    background: #C0392B;
    border-radius: 3px;
    padding: 2px 6px;
    letter-spacing: .02em;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    line-height: 1.4;
    vertical-align: middle;
    position: relative;
    top: -1px;
}

/* ── FILTER BAR ── */
.ldd-filter-bar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 16px;
    grid-column: 1 / -1; /* span su tutta la larghezza della grid .cards */
}
.ldd-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border: 1.5px solid var(--sand-light, #E8D9C8);
    border-radius: 20px;
    background: #fff;
    font-size: 12px;
    font-weight: 500;
    color: #5A5A5A;
    cursor: pointer;
    transition: all .2s ease;
    white-space: nowrap;
}
.ldd-filter-chip span {
    font-size: 11px;
    font-weight: 700;
    color: #9A9A9A;
}
.ldd-filter-chip:hover {
    border-color: var(--sand, #CB9C73);
    color: var(--sand, #CB9C73);
}
.ldd-filter-chip.ldd-filter-active {
    background: var(--sand, #CB9C73);
    border-color: var(--sand, #CB9C73);
    color: #fff;
}
.ldd-filter-chip.ldd-filter-active span {
    color: rgba(255,255,255,.8);
}

/* ── NO IMAGE PLACEHOLDER ── */
.card-img-placeholder {
    width: 100%;
    aspect-ratio: 16/9;
    background: linear-gradient(135deg, #E8E0D8 0%, #D4C9BC 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #8A8A8A;
}
.card-img-placeholder::before {
    content: '🏠';
    font-size: 36px;
    opacity: .45;
}

/* ── PROMO BADGE — lampeggiante ── */
.badge-promo {
    position: absolute;
    top: 11px;
    right: 11px;
    background: #CB9C73;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .06em;
    padding: 5px 11px;
    border-radius: 20px;
    text-transform: uppercase;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    z-index: 2;
    animation: promoBlink 2.4s ease-in-out infinite;
}
@keyframes promoBlink {
    0%,100% { opacity: 1; }
    45%     { opacity: 1; }
    50%     { opacity: .35; }
    55%     { opacity: 1; }
}

/* ── CARD GRID: massimo 3 colonne su desktop wide ── */
@media (min-width: 1200px) {
    .cards { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 900px) and (max-width: 1199px) {
    .cards { grid-template-columns: repeat(2, 1fr); }
}

/* ══════════════════════════════════════════════════════════════
   SEARCH LOADING ANIMATION
══════════════════════════════════════════════════════════════ */
.srch-loading {
    grid-column: 1 / -1;
    background: #FAF8F5;
    border: 1.5px solid #E8E0D8;
    border-radius: 18px;
    padding: 40px 32px 36px;
    text-align: center;
    animation: slFadeIn .35s ease both;
}
@keyframes slFadeIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* Criteri di ricerca */
.srch-criteria {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
}
.srch-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #F2EDE6;
    border: 1px solid #E8E0D8;
    border-radius: 20px;
    padding: 6px 14px;
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 600;
    color: #1A1817;
    letter-spacing: .03em;
}
.srch-chip svg { flex-shrink: 0; color: #CB9C73; }
.srch-chip-sep {
    width: 5px; height: 5px;
    background: #E8E0D8;
    border-radius: 50%;
}

/* Spinner elegante sabbia */
.srch-spinner {
    width: 44px; height: 44px;
    margin: 0 auto 18px;
    border-radius: 50%;
    border: 3px solid #F2EDE6;
    border-top-color: #CB9C73;
    animation: slSpin .85s linear infinite;
}
@keyframes slSpin { to { transform: rotate(360deg); } }

/* Testo animato: scorre tra le frasi */
.srch-msg {
    font-family: 'Cormorant Garamond', serif;
    font-size: 20px;
    font-weight: 500;
    color: #1A1817;
    min-height: 28px;
    margin-bottom: 6px;
    position: relative;
    overflow: hidden;
}
.srch-msg-inner {
    display: inline-block;
    animation: slMsgIn .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes slMsgIn {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
.srch-msg-inner.out {
    animation: slMsgOut .3s ease forwards;
}
@keyframes slMsgOut {
    to { opacity: 0; transform: translateY(-14px); }
}
.srch-sub {
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    color: #8A8A8A;
    letter-spacing: .04em;
}

/* Barra progresso indeterminata */
.srch-progress {
    height: 2px;
    background: #F2EDE6;
    border-radius: 2px;
    margin-top: 24px;
    overflow: hidden;
}
.srch-progress-bar {
    height: 100%;
    width: 35%;
    background: linear-gradient(90deg, #F2EDE6, #CB9C73, #F2EDE6);
    border-radius: 2px;
    animation: slProg 1.6s ease-in-out infinite;
}
@keyframes slProg {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(380%); }
}

/* ── CHIP COUNT e RESET dentro il box ── */
.rl-chip-count {
    font-weight: 700;
    background: #CB9C73;
    color: #fff;
    border-color: #CB9C73;
}
.rl-chip-reset {
    background: transparent;
    border: 1px solid #E8E0D8;
    color: #5A5A5A;
    cursor: pointer;
    gap: 5px;
    font-family: 'Montserrat', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .03em;
    margin-left: auto;
    transition: all .15s;
}
.rl-chip-reset:hover {
    background: #F2EDE6;
    border-color: #CB9C73;
    color: #1A1817;
}

/* ══════════════════════════════════════════════════════════════
   GLOBAL STATS BANNER — sopra la search bar
══════════════════════════════════════════════════════════════ */
.ldd-gstats {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
    background: #FAF8F5;
    border: 1.5px solid #CB9C73;
    border-radius: 14px;
    padding: 22px 32px;
    margin-bottom: 20px;
    box-shadow: 0 4px 20px rgba(26,24,23,.07);
}
.ldd-gs-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 36px;
}
.ldd-gs-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 44px;
    font-weight: 300;
    color: #6A8F70;
    line-height: 1;
    letter-spacing: -.02em;
    /* Larghezza fissa per evitare layout shift durante count-up */
    min-width: 3ch;
    text-align: center;
    transition: opacity .2s;
}
.ldd-gs-lbl {
    font-family: 'Montserrat', sans-serif;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #8A8A8A;
    margin-top: 5px;
    white-space: nowrap;
}
.ldd-gs-sep {
    width: 1px;
    height: 48px;
    background: #E8E0D8;
    flex-shrink: 0;
}
@media (max-width: 580px) {
    .ldd-gstats  { padding: 12px 8px; gap: 0; flex-wrap: nowrap; }
    .ldd-gs-item { padding: 0 8px; }
    .ldd-gs-num  { font-size: 22px; min-width: 2ch; }
    .ldd-gs-lbl  { font-size: 8px; letter-spacing: .05em; }
    .ldd-gs-sep  { height: 32px; }
}

/* ── About section: animazione durante il caricamento cards ────────── */

/* Stato loading: appare sopra il loader con slide-up elegante */
.ldd-about-loading {
    animation: lddAboutUp 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
    margin-bottom: 2rem;
}

@keyframes lddAboutUp {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
