/* Estilos extraídos desde el HTML original */

:root{
  --white:#FFFFFF;--off:#F8F6F2;--border:#DDD9D0;--border2:#C8C2B8;
  --black:#1A1A16;
  --gray:#3D3A36;        /* texto principal secundario — sube de #6B6660 */
  --gray-md:#6B6660;     /* texto decorativo medio */
  --gray-lt:#8C8680;     /* labels uppercase pequeños — sube de #A8A39C */
  --gold:#C9A96E;--gold-dk:#9A7540;--gold-lt:#E8D8B4;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"DM Sans",system-ui,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px}
body{font-family:var(--sans);background:var(--white);color:var(--black);-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* Elementos solo-móvil: ocultos en escritorio */
.sb-toggle-icon,.sb-toggle-label,.sb-filter-count{display:none}

/* LAYOUT */
.layout{display:grid;grid-template-columns:300px 1fr;height:calc(100vh - 74px);min-height:520px;align-items:stretch}
.hero{background:var(--off);border-bottom:1px solid var(--border);padding:32px 28px 26px;display:flex;align-items:flex-end;justify-content:space-between;gap:20px}
.hero-eyebrow{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:500}
.hero-h1{font-family:var(--serif);font-size:clamp(1.8rem,2.8vw,2.8rem);font-weight:400;line-height:1.1;color:var(--black)}
.hero-h1 em{color:var(--gold);font-style:italic}
.hero-p{margin-top:8px;font-size:.82rem;color:var(--gray);line-height:1.6;max-width:400px}
.hero-stat{text-align:right;flex-shrink:0}
.hero-stat-n{font-family:var(--serif);font-size:3.2rem;font-weight:400;line-height:1;transition:all .3s;color:var(--black)}
.hero-stat-l{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-lt);margin-top:2px}

/* LAYOUT */
.layout{display:grid;grid-template-columns:300px 1fr;height:calc(100vh - 134px);min-height:520px;align-items:stretch}

/* SIDEBAR */
.sb{background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:visible;height:100%}
.sb-head{padding:14px 20px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sb-title{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gray-lt);font-weight:500}
.btn-reset{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--white);background:var(--gray-md);border:none;cursor:pointer;font-family:var(--sans);padding:5px 11px;border-radius:2px;transition:all .2s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.btn-reset:hover{background:var(--black);opacity:1}
.sb-body{flex:1;overflow-y:visible;padding:16px 20px;display:flex;flex-direction:column;gap:18px;min-height:0}
.sb-body::-webkit-scrollbar{width:2px}
.sb-body::-webkit-scrollbar-thumb{background:var(--gold-lt)}
.fg-label{display:block;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-lt);font-weight:500;margin-bottom:8px}
.sl-disp{font-family:var(--serif);font-size:1.35rem;font-weight:300;color:var(--black);margin-bottom:7px;line-height:1}
.sl-disp b{color:var(--gold-dk);font-weight:400}
input[type="range"]{-webkit-appearance:none;width:100%;height:1px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--gold) 0%,var(--gold) var(--pct,25%),var(--border2) var(--pct,25%),var(--border2) 100%)}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:var(--gold);border:2px solid var(--white);box-shadow:0 0 0 1px var(--gold-dk);cursor:pointer;transition:transform .15s}
input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.2)}
.pills{display:flex;flex-wrap:wrap;gap:5px}
.pill{padding:5px 11px;border:1px solid var(--border2);background:transparent;font-family:var(--sans);font-size:.72rem;letter-spacing:.02em;color:var(--gray);cursor:pointer;transition:all .15s;border-radius:2px;line-height:1.4}
.pill:hover{border-color:var(--gold);color:var(--gold-dk)}
.pill.on{background:var(--black);border-color:var(--black);color:var(--white)}

/* TOGGLE TERRAZA */
.toggle-wrap{display:flex;align-items:center}
.toggle-btn{display:flex;align-items:center;gap:11px;background:none;border:none;cursor:pointer;padding:0;font-family:var(--sans)}
.toggle-track{
  position:relative;width:48px;height:26px;border-radius:13px;
  background:var(--border2);border:1.5px solid var(--border2);
  transition:background .25s,border-color .25s;
  flex-shrink:0;
}
.toggle-thumb{
  position:absolute;top:3px;left:3px;
  width:18px;height:18px;border-radius:50%;
  background:var(--white);
  box-shadow:0 1px 4px rgba(0,0,0,.22);
  transition:transform .25s cubic-bezier(0.16,1,0.3,1),background .25s;
}
.toggle-btn[aria-pressed="true"] .toggle-track{
  background:var(--black);border-color:var(--black);
}
.toggle-btn[aria-pressed="true"] .toggle-thumb{
  transform:translateX(22px);
  background:var(--gold);
  box-shadow:0 1px 6px rgba(201,169,110,.5);
}
.toggle-label{
  font-size:.75rem;color:var(--gray);
  transition:color .2s;line-height:1;
}
.toggle-btn[aria-pressed="true"] .toggle-label{
  color:var(--black);font-weight:500;
}
.sb-foot{flex-shrink:0;border-top:2px solid var(--border);padding:14px 20px 16px;background:var(--white);box-shadow:0 -4px 16px rgba(0,0,0,.07)}
.res-row{display:flex;align-items:baseline;gap:7px;margin-bottom:12px}
.res-n{font-family:var(--serif);font-size:1.8rem;font-weight:300;color:var(--black);line-height:1;transition:all .3s}
.res-lbl{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-md)}
.btn-ver{width:100%;padding:13px;border:none;background:var(--gold);color:var(--black);font-family:var(--sans);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:all .2s}
.btn-ver:hover{background:var(--gold-dk);color:var(--white)}
.btn-ver:disabled{background:var(--border);color:var(--gray-lt);cursor:not-allowed}

/* MAPA */
.map-wrap{position:relative;background:var(--off)}
#map{width:100%;height:100%}
.leaflet-container{font-family:var(--sans);background:var(--off)}

/* POPUP ESPACIO */
.space-popup{
  display:none;position:fixed;bottom:28px;left:50%;transform:translateX(-50%);
  background:var(--white);border-top:3px solid var(--gold);
  box-shadow:0 8px 32px rgba(0,0,0,.18);z-index:800;
  width:400px;max-width:calc(100vw - 32px);
  animation:slideUp .25s var(--ease);
}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.popup-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:1.1rem;color:var(--gray-lt);cursor:pointer;line-height:1;z-index:1}
.popup-close:hover{color:var(--black)}
.popup-inner{display:flex;gap:0}
.popup-img{width:110px;flex-shrink:0;background:var(--off);overflow:hidden;min-height:120px;display:flex;align-items:center;justify-content:center}
.popup-img img{width:100%;height:100%;object-fit:cover;display:block}
.popup-img-ph{font-family:var(--serif);font-size:2.2rem;color:var(--gold-lt)}
.popup-content{padding:14px 16px 14px 14px;flex:1}
.popup-cat{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-dk);margin-bottom:4px;font-weight:500}
.popup-name{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:var(--black);line-height:1.15;margin-bottom:6px}
.popup-info{font-size:.75rem;color:var(--gray);line-height:1.55;margin-bottom:12px}
.popup-info b{color:var(--gold-dk);font-weight:500}
.btn-quiero{width:100%;padding:10px;background:var(--black);border:none;font-family:var(--sans);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--white);cursor:pointer;transition:background .2s}
.btn-quiero:hover{background:var(--gold-dk)}

/* OVERLAY / MODAL */
.overlay{position:fixed;inset:0;background:rgba(26,26,22,.65);backdrop-filter:blur(5px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--white);width:100%;max-width:700px;max-height:92vh;overflow-y:auto;position:relative;transform:translateY(20px);transition:transform .35s var(--ease);border-top:3px solid var(--gold)}
.modal::-webkit-scrollbar{width:2px}
.modal::-webkit-scrollbar-thumb{background:var(--gold-lt)}
.overlay.open .modal{transform:translateY(0)}
.m-head{padding:24px 28px 18px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between}
.m-eyebrow{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-dk);margin-bottom:6px;font-weight:500}
.m-title{font-family:var(--serif);font-size:1.7rem;font-weight:400;color:var(--black);line-height:1.12;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-title em{color:var(--gold);font-style:italic;white-space:nowrap}
.m-sub{margin-top:5px;font-size:.8rem;color:var(--gray);line-height:1.55}
.btn-close{background:none;border:none;font-size:1.2rem;color:var(--gray-lt);cursor:pointer;line-height:1;padding:4px;flex-shrink:0}
.btn-close:hover{color:var(--black)}
.m-steps{display:flex;border-bottom:none}
.m-step{flex:1;padding:11px 12px;text-align:center;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--black);border-bottom:2px solid transparent;margin-bottom:0;transition:opacity .35s,border-color .35s,color .35s;opacity:0.22;font-weight:400}
.m-step.active{color:var(--black);border-bottom:2px solid var(--gold);font-weight:500;opacity:1}
.m-step.inactive{opacity:0.18;border-bottom:2px solid transparent;color:var(--gray-lt)}
.prog-bar{height:2px;background:var(--border)}
.prog-fill{height:100%;background:var(--gold);transition:width .4s var(--ease)}
.m-body{padding:24px 28px 28px}
.m-panel{display:none}
.m-panel.active{display:block}

/* Tarjetas */
.spaces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}
.sc{border:1.5px solid var(--border2);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;height:auto}
.sc:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.sc.on{border-color:var(--black);box-shadow:0 0 0 1px var(--black)}
.sc-img{height:110px;background:var(--off);overflow:hidden;position:relative}
.sc-img img{width:100%;height:100%;object-fit:cover}
.sc-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.8rem;color:var(--gold-lt)}
.sc-badge{position:absolute;top:8px;left:8px;font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;background:var(--black);color:var(--white);padding:3px 7px}
.sc-badge.rec{background:var(--gold);color:var(--black)}
.sc-body{padding:10px 12px 12px;flex:1;display:flex;flex-direction:column}
.sc-name{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--black);line-height:1.2;margin-bottom:5px}
.sc-info{font-size:.7rem;color:var(--gray);line-height:1.5;margin-bottom:2px}
.sc-info b{color:var(--gold-dk);font-weight:500}
.sc-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border2);margin-top:10px;display:flex;align-items:center;justify-content:center;font-size:.65rem;transition:all .2s;align-self:flex-end;color:transparent}
.sc.on .sc-check{background:var(--black);border-color:var(--black);color:var(--white)}
.sc-desc{font-size:.72rem;color:var(--gray-md);line-height:1.55;margin-top:6px;font-style:italic;flex:1}
.no-res{text-align:center;padding:32px 20px}
.no-res-icon{font-family:var(--serif);font-size:2rem;color:var(--gold-lt);margin-bottom:10px}
.no-res h3{font-family:var(--serif);font-size:1.3rem;font-weight:300;margin-bottom:6px;color:var(--black)}
.no-res p{font-size:.8rem;color:var(--gray);line-height:1.5}

/* Formulario */
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-grid.one{grid-template-columns:1fr}
.f{display:flex;flex-direction:column;gap:6px}
.f.s2{grid-column:1/-1}
.f-lbl{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-lt);font-weight:500}
.f input,.f select,.f textarea{font-family:var(--sans);font-size:.88rem;padding:10px 12px;border:1px solid var(--border2);background:var(--white);color:var(--black);outline:none;-webkit-appearance:none;transition:border-color .18s}
.f input::placeholder,.f textarea::placeholder{color:var(--gray-lt)}
.f input:focus,.f select:focus,.f textarea:focus{border-color:var(--gold);border-width:1.5px}
.f textarea{min-height:80px;resize:vertical}
.sel-wr{position:relative}
.sel-wr::after{content:"↓";position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:.7rem;pointer-events:none}
.sel-tag{display:flex;align-items:center;gap:8px;padding:9px 13px;background:var(--off);border:1px solid var(--border);font-size:.75rem;color:var(--black);margin-bottom:18px;flex-wrap:wrap}
.sel-tag-lbl{color:var(--gray-lt);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.sel-tag-val{font-family:var(--serif);font-style:italic;color:var(--gold-dk);font-size:.9rem}
.summary{background:var(--off);border:1px solid var(--border);padding:14px 16px;margin-bottom:18px}
.summary-title{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-lt);margin-bottom:10px;font-weight:500}
.summary-items{display:flex;flex-wrap:wrap;gap:6px}
.summary-item{display:flex;align-items:center;gap:6px;padding:5px 11px;background:var(--white);border:1px solid var(--border2);font-size:.73rem;color:var(--black)}
.summary-icon{color:var(--gold);font-size:.75rem}
.f-nav{display:flex;gap:10px;margin-top:22px;padding-top:16px;border-top:1px solid var(--border)}
.btn-next{flex:1;padding:12px;background:var(--black);border:none;font-family:var(--sans);font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;color:var(--white);cursor:pointer;transition:background .2s}
.btn-next:hover{background:var(--gold-dk)}
.btn-next:disabled{background:var(--border);color:var(--gray-lt);cursor:not-allowed}
.btn-back{padding:12px 16px;background:none;border:1px solid var(--border2);font-family:var(--sans);font-size:.67rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-md);cursor:pointer;transition:all .18s}
.btn-back:hover{border-color:var(--black);color:var(--black)}
.btn-submit{flex:1;padding:12px;background:var(--gold);border:none;font-family:var(--sans);font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;color:var(--black);cursor:pointer;transition:background .2s}
.btn-submit:hover{background:var(--gold-dk);color:var(--white)}
.privacy{margin-top:10px;font-size:.7rem;color:var(--gray-md);line-height:1.5}
.privacy a{color:var(--gold-dk);text-decoration:none}
.privacy a:hover{text-decoration:underline}
.f-ok{display:none;text-align:center;padding:36px 20px}
.f-ok.show{display:block}
.ok-icon{font-family:var(--serif);font-size:2.8rem;color:var(--gold);margin-bottom:14px}
.ok-h{font-family:var(--serif);font-size:1.9rem;font-weight:300;margin-bottom:8px;color:var(--black)}
.ok-p{font-size:.82rem;color:var(--gray);line-height:1.6;max-width:360px;margin:0 auto}
.ok-p b{color:var(--gold-dk);font-weight:500;font-style:italic}
.ok-tel{display:inline-block;margin-top:16px;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-md);border:1px solid var(--border2);padding:9px 16px}
.ok-actions{display:flex;gap:10px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.ok-btn-new{padding:12px 22px;background:none;border:1px solid var(--border2);font-family:var(--sans);font-size:.67rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-md);cursor:pointer;transition:all .2s}
.ok-btn-new:hover{border-color:var(--black);color:var(--black)}
.ok-btn-home{padding:12px 22px;background:var(--gold);border:none;font-family:var(--sans);font-size:.67rem;letter-spacing:.15em;text-transform:uppercase;color:var(--black);cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center}
.ok-btn-home:hover{background:var(--gold-dk);color:var(--white)}

/* ─── MOBILE ≤ 768px ──────────────────────────────────────────────────────── */
@media(max-width:768px){

  /* Reactiva elementos solo-móvil */
  .sb-toggle-icon,.sb-toggle-label{display:inline-block}
  .sb-filter-count{display:none} /* se muestra vía JS con .visible */
  .sb-filter-count.visible{display:inline-flex}

  /* NAV */
  nav{padding:0 16px}
  .nav-links{display:none}

  /* HERO: compacto, sin stat */
  .hero{flex-direction:column;align-items:flex-start;padding:16px 16px 14px;gap:6px}
  .hero-stat{display:none}
  .hero-eyebrow{margin-bottom:4px}
  .hero-h1{font-size:1.5rem}
  .hero-p{display:none}

  /* LAYOUT: columna única, altura automática */
  .layout{
    display:flex;
    flex-direction:column;
    height:auto;
    min-height:0;
  }

  /* SIDEBAR ─ acordeón ───────────────────────────────────────────────────── */
  .sb{
    border-right:none;
    border-bottom:1px solid var(--border);
    overflow:visible;   /* permite que el body se expanda */
    height:auto;
    position:relative;
    z-index:10;
    background:var(--white);
  }

  /* Cabecera: siempre visible, actúa como toggle */
  .sb-head{
    padding:13px 16px;
    cursor:pointer;
    user-select:none;
    -webkit-user-select:none;
  }
  .sb-head:active{background:var(--off)}

  /* Flecha indicadora de estado */
  .sb-toggle-icon{
    display:inline-block;
    font-size:.75rem;
    color:var(--gold);
    transition:transform .3s var(--ease);
    margin-left:2px;
    line-height:1;
  }
  .sb.open .sb-toggle-icon{transform:rotate(180deg)}
  .sb-toggle-label{
    font-size:.6rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--gray-md);
  }

  /* Badge con nº de filtros activos */
  .sb-filter-count{
    align-items:center;
    justify-content:center;
    width:18px;height:18px;
    border-radius:50%;
    background:var(--gold);
    color:var(--black);
    font-size:.55rem;
    font-weight:600;
    margin-left:6px;
    line-height:1;
  }

  /* Cuerpo de filtros: colapsado por defecto */
  .sb-body{
    max-height:0;
    overflow:hidden;
    padding:0 16px;
    transition:max-height .4s var(--ease), padding .3s var(--ease);
  }
  .sb.open .sb-body{
    max-height:1200px;   /* suficientemente grande para todo el contenido */
    padding:14px 16px;
    overflow-y:auto;
  }

  /* Pie: siempre visible */
  .sb-foot{
    padding:12px 16px 14px;
    box-shadow:none;
    border-top:1px solid var(--border);
  }
  /* Cuando el acordeón está cerrado, el pie tiene un borde superior limpio */
  .sb:not(.open) .sb-foot{border-top-color:transparent}

  /* MAPA: buena altura fija */
  .map-wrap{height:55vh;min-height:320px}
  #map{width:100%;height:100%}

  /* POPUP en móvil: ancho completo, un poco más alto */
  .space-popup{width:calc(100vw - 24px);bottom:16px}
  .popup-img{width:90px}

  /* MODAL */
  .modal{max-width:100%;max-height:100svh;border-radius:0}
  .m-body{padding:16px 16px 24px}
  .m-head{padding:16px 16px 12px}
  .m-title{white-space:normal;font-size:1.35rem}
  .f-grid{grid-template-columns:1fr}
  .spaces-grid{grid-template-columns:1fr 1fr}
  .m-step{font-size:.54rem;padding:10px 6px;letter-spacing:.08em}
}


/* ── Modo iframe: sin margen extra, ocupa todo el contenedor ── */
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
  overflow-x: hidden;
}
