.cottage-map-wrap{display:grid;grid-template-columns:330px 1fr;gap:24px;align-items:start;width:100%;box-sizing:border-box}.cottage-map-panel{background:#fff;border:1px solid #e3e7ea;border-radius:14px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.06);font-size:14px}.cottage-map-panel h3{margin:0 0 14px;font-size:20px}.cottage-map-field{margin-bottom:18px}.cottage-map-field label{display:block;margin-bottom:8px;font-weight:700}.cottage-map-wrap{--cottage-accent:rgb(209, 194, 146)}.cottage-map-field input[type=search]{width:100%;box-sizing:border-box;padding:8px;border:1px solid #ccd0d4;border-radius:8px;background:#fff}.cottage-map-checkbox{display:flex;gap:8px;align-items:center;margin:10px 0 18px}.cottage-map-checkbox input{width:auto}.cottage-map-reset{width:100%;padding:9px;border:0;border-radius:8px;background:#1f2937;color:#fff;cursor:pointer}.cottage-map-count{margin:10px 0 16px;color:#111827}.range-labels{display:flex;justify-content:space-between;gap:10px;margin-bottom:4px}.range-labels span{font-size:12px;font-weight:700;background:#f8fafc;border:1px solid #dce3ea;border-radius:6px;padding:3px 7px}.range-title{text-align:center;font-weight:700;margin-bottom:4px}.range-dual{position:relative;height:26px}.range-dual input[type=range]{position:absolute;left:0;right:0;width:100%;pointer-events:none;appearance:none;background:transparent;margin:0;top:3px}.range-dual input[type=range]::-webkit-slider-thumb{pointer-events:auto;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--cottage-accent);box-shadow:0 1px 5px rgba(0,0,0,.25);cursor:pointer}.range-dual input[type=range]::-moz-range-thumb{pointer-events:auto;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--cottage-accent);box-shadow:0 1px 5px rgba(0,0,0,.25);cursor:pointer}.range-track{height:6px;background:rgb(209, 194, 146);border-radius:999px;position:absolute;left:8px;right:8px;top:9px}.cottage-map-list{max-height:420px;overflow:auto;border:1px solid #edf0f2;margin-top:16px}.cottage-map-list-item{display:grid;grid-template-columns:52px 1fr;gap:6px;padding:10px;border-bottom:1px solid #edf0f2;cursor:pointer}.cottage-map-list-item:hover{background:#f9fafb}.cottage-map-list-id{font-weight:700}.cottage-map-list-meta{color:#4b5563;font-size:13px}.cottage-map-canvas{position:relative;min-height:480px;background:#f3f5f1;border-radius:16px;overflow:hidden;border:1px solid #e3e7ea}.cottage-map-svg{width:100%;height:auto;display:block}.cottage-map-svg svg{width:100%;height:auto;display:block}.cottage-tooltip{position:absolute;display:none;z-index:5;min-width:240px;max-width:320px;background:#fff;border-radius:14px;padding:16px;box-shadow:0 12px 35px rgba(0,0,0,.22);pointer-events:none}.cottage-tooltip h4{margin:0 0 6px;font-size:18px}.cottage-tooltip .status{font-weight:700;margin-bottom:8px}.cottage-tooltip p{margin:5px 0}.tip-close{position:absolute;right:10px;top:8px;border:0;background:transparent;font-size:20px;color:#6b7280}.cottage-legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:18px;font-size:14px}.cottage-legend span{display:inline-flex;gap:7px;align-items:center}.cottage-legend i{width:18px;height:18px;border-radius:4px;display:inline-block}.legend-status-title{margin-left:10px}.legend-sold{background:repeating-linear-gradient(45deg,#ff2b2b 0,#ff2b2b 6px,#fff 6px,#fff 9px);border:1px solid #ff2b2b}.legend-booked{background:repeating-linear-gradient(45deg,#9ca3af 0,#9ca3af 6px,#fff 6px,#fff 9px);border:1px solid #9ca3af}.cottage-map-wrap .plot-sold{opacity:.62}.cottage-map-wrap .plot-booked{opacity:.75;stroke-dasharray:4 3}.cottage-map-wrap .plot-hidden{opacity:.12!important}.cottage-map-wrap .plot-active{stroke:#111!important;stroke-width:4px!important;filter:drop-shadow(0 3px 3px rgba(0,0,0,.35))}.cottage-map-wrap [data-cottage-plot]{cursor:pointer;transition:opacity .15s ease,filter .15s ease}
@media(max-width:900px){.cottage-map-wrap{grid-template-columns:1fr}.cottage-map-panel{order:2}.cottage-map-canvas{order:1;min-height:280px}.cottage-map-list{max-height:260px}}

.cottage-map-wrap input[type=range]{accent-color:rgb(209, 194, 146)}
.cottage-map-wrap input[type=checkbox]{accent-color:rgb(209, 194, 146)}
.cottage-map-wrap input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:999px}
.cottage-map-wrap input[type=range]::-moz-range-track{height:6px;border-radius:999px}


/* v0.8 layout: filters + list + map */
.cottage-map-wrap{grid-template-columns:330px 280px minmax(0,1fr)!important;gap:16px!important;align-items:start!important}
.cottage-map-panel,.cottage-map-list-panel{background:#fff;border:1px solid #e3e7ea;border-radius:14px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.06);font-size:14px;box-sizing:border-box}
.cottage-map-list-panel h3{margin:0 0 12px;font-size:20px}
.cottage-map-list{max-height:640px;overflow:auto;border:1px solid #edf0f2;margin-top:0;border-radius:10px;background:#fff}
.cottage-map-list-item{display:grid;grid-template-columns:58px 1fr;gap:6px;padding:11px 10px;border-bottom:1px solid #edf0f2;cursor:pointer;align-items:start}
.cottage-map-list-status-sold .cottage-map-list-id{color:#ef2b22}
.cottage-map-list-status-booked .cottage-map-list-id{color:#8d949e}
.cottage-map-list-empty{padding:14px;color:#6b7280}
.cottage-map-section{min-width:0}
.cottage-map-wrap .plot-sold{fill:#ef2b22!important;opacity:1!important;stroke:#fff!important;stroke-width:2px!important;stroke-dasharray:none!important}
.cottage-map-wrap .plot-booked{fill:#9ca3af!important;opacity:1!important;stroke:#fff!important;stroke-width:2px!important;stroke-dasharray:none!important}
.legend-sold{background:#ef2b22!important;border:1px solid #ef2b22!important}
.legend-booked{background:#9ca3af!important;border:1px solid #9ca3af!important}
@media(max-width:1100px){.cottage-map-wrap{grid-template-columns:300px 1fr!important}.cottage-map-list-panel{order:3;grid-column:1 / -1}.cottage-map-section{grid-column:auto}}
@media(max-width:900px){.cottage-map-wrap{grid-template-columns:1fr!important}.cottage-map-panel{order:2}.cottage-map-list-panel{order:3;grid-column:auto}.cottage-map-section{order:1}.cottage-map-canvas{min-height:280px}.cottage-map-list{max-height:320px}}


/* v0.9 layout: 25% filters / 25% list / 50% map, equal block height */
.cottage-map-wrap{
  --cottage-block-height: 560px;
  grid-template-columns: minmax(240px,1fr) minmax(240px,1fr) minmax(0,2fr)!important;
  align-items:stretch!important;
}
.cottage-map-panel,
.cottage-map-list-panel,
.cottage-map-section{
  height:var(--cottage-block-height);
  box-sizing:border-box;
}
.cottage-map-panel,
.cottage-map-list-panel{
  overflow:hidden;
}
.cottage-map-list-panel{
  display:flex;
  flex-direction:column;
}
.cottage-map-list-panel h3{
  flex:0 0 auto;
}
.cottage-map-list{
  flex:1 1 auto;
  max-height:none!important;
  min-height:0;
}
.cottage-map-section{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.cottage-map-canvas{
  flex:1 1 auto;
  min-height:0!important;
  height:auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.cottage-map-svg{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.cottage-map-svg svg{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}
.cottage-legend{
  flex:0 0 auto;
  margin-top:14px;
}
@media(max-width:1100px){
  .cottage-map-wrap{grid-template-columns:1fr 1fr!important}
  .cottage-map-section{grid-column:1 / -1;height:auto!important}
  .cottage-map-canvas{min-height:360px!important}
}
@media(max-width:900px){
  .cottage-map-wrap{grid-template-columns:1fr!important}
  .cottage-map-panel,.cottage-map-list-panel{height:auto!important;min-height:0}
  .cottage-map-list{max-height:360px!important}
}


/* v1.0 pan and zoom controls */
.cottage-map-canvas{touch-action:none;cursor:grab;}
.cottage-map-canvas.is-dragging-map{cursor:grabbing;}
.cottage-map-svg svg{will-change:transform;transform-origin:0 0;transition:transform .08s ease-out;}
.cottage-map-canvas.is-dragging-map .cottage-map-svg svg{transition:none;}
.cottage-map-zoom-controls{position:absolute;left:14px;top:14px;z-index:8;display:flex;flex-direction:column;gap:6px;}
.cottage-map-zoom-controls button{width:36px;height:36px;border:1px solid #d8dee6;border-radius:8px;background:#fff;color:#111827;font-size:22px;line-height:1;font-weight:700;box-shadow:0 4px 12px rgba(0,0,0,.12);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.cottage-map-zoom-controls button[data-zoom-reset]{font-size:17px;}
.cottage-map-zoom-controls button:hover{background:#f8fafc;}
.cottage-map-svg.is-zoomed [data-cottage-plot]{cursor:pointer;}

/* v1.1: prevent selecting SVG labels while panning */
.cottage-map-canvas,
.cottage-map-canvas *,
.cottage-map-svg,
.cottage-map-svg *{
  -webkit-user-select:none!important;
  -moz-user-select:none!important;
  -ms-user-select:none!important;
  user-select:none!important;
}
.cottage-map-svg text,
.cottage-map-svg tspan{
  pointer-events:none!important;
  -webkit-user-select:none!important;
  user-select:none!important;
}


/* v1.2: centered map and tooltip status colors */
.cottage-tooltip .status-free{color:#16a34a!important;}
.cottage-tooltip .status-sold{color:#ef2b22!important;}
.cottage-tooltip .status-booked{color:#6b7280!important;}
.cottage-map-canvas{align-items:center!important;justify-content:center!important;}

/* v1.4: crisp SVG zoom via viewBox instead of CSS transform */
.cottage-map-svg svg{
  transform:none!important;
  transition:none!important;
  image-rendering:auto;
  shape-rendering:auto;
  text-rendering:geometricPrecision;
}
.cottage-tooltip{
  pointer-events:auto;
}
