/* Panelario — manufacturers.html page styles */

nav{z-index:1000}

.page-header {
  padding:88px 40px 28px;text-align:center;
}
.page-header .section-label {
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--accent-active);margin-bottom:8px;
}
.page-header h1 {
  font-size:clamp(22px,3vw,34px);
  font-weight:700;line-height:1.15;margin-bottom:10px;color:var(--accent);
}
.page-header p {
  font-size:13px;color:var(--text-secondary);max-width:480px;margin:0 auto;line-height:1.7;
}

.map-wrapper {
  padding:0 40px 4px;max-width:1200px;margin:0 auto;position:relative;z-index:1;
}
#map {
  width:100%;height:100%;position:relative;
  border-radius:var(--radius);border:1px solid var(--border);z-index:1;
  overflow:hidden;transition:border-radius .3s ease;
}
#map.demand-open{border-radius:var(--radius);border-left:1px solid var(--border)}
.map-col{flex:1;min-width:0;position:relative}
.map-toast {
  position:absolute;bottom:48px;left:50%;transform:translateX(-50%) translateY(8px);z-index:1100;
  background:rgba(26,25,22,0.94);color:var(--text-primary);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:8px 16px;font-size:11px;
  backdrop-filter:blur(8px);pointer-events:none;opacity:0;transition:opacity .3s,transform .3s;
  white-space:nowrap;
}
.map-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}
.map-col #map{height:620px}
.map-toolbar {
  position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:1000;
  display:flex;flex-direction:column;gap:4px;align-items:stretch;pointer-events:none;
  width:auto;
}
.map-toolbar > *{pointer-events:auto}
.map-search-row {
  display:flex;gap:4px;align-items:center;
}
.map-search-row input {
  flex:1;height:28px;
  padding:0 12px;font-size:11px;font-family:inherit;
  background:rgba(35,34,32,0.92);color:var(--text-primary);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  outline:none;transition:border-color .15s;
  backdrop-filter:blur(8px);
}
.map-search-row input:focus{border-color:var(--border-hover)}
.map-search-row input::placeholder{color:var(--text-muted)}
.map-search-row button {
  height:28px;padding:0 12px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-family:inherit;cursor:pointer;white-space:nowrap;
  background:rgba(44,42,39,0.92);color:var(--text-primary);
  border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s;
  backdrop-filter:blur(8px);
}
.map-search-row button:hover{border-color:var(--border-hover);color:var(--text-primary)}
.map-search-row .btn-locate{
  background:var(--accent-active);color:var(--bg-primary);border-color:var(--accent-active);
}
.map-search-row .btn-locate:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--bg-primary)}
.map-filter-row {
  display:flex;align-items:center;gap:4px;flex-wrap:wrap;
}
.map-filter-row .filter-btn,
.map-filter-row .filter-check,
.map-filter-row .filter-sep {
  backdrop-filter:blur(8px);
  background:rgba(44,42,39,0.88);
}
.map-filter-row .filter-sep{background:var(--border)}
.map-filter-dropdown {
  backdrop-filter:blur(8px);
  background:rgba(35,34,32,0.94);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px 10px;
}
.map-filter-dropdown .filter-chips{background:transparent;border:none;padding:0}

.leaflet-tile-pane{filter:brightness(0.75) contrast(1.1) saturate(0.3) sepia(0.15)}
/* Zoom control — dark UI buttons, no borders, top-aligned with the search bar */
.leaflet-top.leaflet-left .leaflet-control-zoom{margin:8px 0 0 8px !important;border:none !important;box-shadow:none !important;display:flex;flex-direction:row}
.leaflet-control-zoom a{
  background:rgba(44,42,39,0.92) !important;color:var(--text-secondary) !important;
  border:none !important;border-radius:var(--radius-sm) !important;
  width:28px !important;height:28px !important;line-height:28px !important;backdrop-filter:blur(8px);transition:all .15s;
}
.leaflet-control-zoom a:last-child{margin-top:0;margin-left:3px}
.leaflet-control-zoom a:hover{background:var(--bg-tertiary) !important;color:var(--accent-active) !important}
.leaflet-control-zoom a.leaflet-disabled{color:var(--text-muted) !important;opacity:.5}
.leaflet-control-attribution{
  background:rgba(26,25,22,0.7) !important;color:var(--text-muted) !important;font-size:10px !important;
}
.leaflet-control-attribution a{color:var(--text-secondary) !important}

.leaflet-popup-content-wrapper{
  background:var(--bg-secondary) !important;color:var(--text-primary) !important;
  border:1px solid var(--border) !important;border-radius:var(--radius) !important;
  box-shadow:0 8px 32px rgba(0,0,0,0.5) !important;
}
.leaflet-popup-tip{background:var(--bg-secondary) !important}
.leaflet-popup-content{margin:14px 16px !important;font-size:12px;min-width:220px}
.popup-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:4px}
.popup-logo{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid var(--border)}
.popup-logo.logo-png{border:none;border-radius:0;object-fit:contain;background:transparent}
.popup-header .popup-name{margin-bottom:2px}
.popup-header .popup-type{margin-bottom:0}
.popup-name{font-weight:700;font-size:13px;margin-bottom:4px}
.popup-type{font-size:10px;color:var(--accent-active);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.popup-info{color:var(--text-secondary);font-size:11px;line-height:1.7}
.popup-info a{color:var(--accent-active)}
.popup-radius{display:inline-flex;align-items:center;gap:4px;margin-top:6px;padding:3px 8px;background:var(--accent-dim);border-radius:var(--radius-sm);font-size:10px;color:var(--accent-active)}

.location-badge {
  display:none;align-items:center;gap:6px;
  font-size:10px;color:var(--accent-active);
  padding:4px 10px;background:rgba(44,42,39,0.92);border:1px solid var(--border);border-radius:var(--radius-sm);
  backdrop-filter:blur(8px);
}
.location-badge.visible{display:inline-flex}
/* Inline clear ✕ inside the search input */
.search-input-wrap{flex:1;position:relative;display:flex}
.search-input-wrap input{padding-right:26px!important}
.map-search-row .search-clear{position:absolute;right:5px;top:50%;transform:translateY(-50%);width:18px;height:18px;padding:0;background:none;border:none;color:var(--text-muted);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:none}
.map-search-row .search-clear:hover{color:var(--text-primary);border:none;background:none}
/* CTA banner buttons — equal width */
.mfr-cta-btn{min-width:172px;display:inline-flex;align-items:center;justify-content:center;text-align:center}


.map-bottom-left {
  position:absolute;bottom:28px;left:12px;z-index:800;
  display:flex;align-items:flex-end;gap:6px;pointer-events:none;
}
.map-bottom-left > *{pointer-events:auto}
.mbl-check {
  background:rgba(26,25,22,0.92);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:4px 10px;
  backdrop-filter:blur(8px);font-size:10px;cursor:pointer;
}

/* ── Map + Demand side-by-side ── */
.map-row {display:flex;gap:4px;align-items:stretch}

/* ── Demand stats panel (right of map) ── */
.demand-panel {
  width:200px;overflow:hidden;
  background:var(--bg-secondary);border:1px solid var(--border);
  border-radius:var(--radius);
  display:flex;flex-direction:column;gap:10px;
  padding:14px 16px;
}
.dp-header {text-align:center;padding-bottom:6px;border-bottom:1px solid var(--border);flex-shrink:0}
.dp-stat-num {font-size:28px;font-weight:700;color:var(--accent-active);line-height:1}
.dp-stat-label {font-size:7px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-top:3px}
.dp-tabs {display:flex;gap:0;border-bottom:1px solid var(--border);flex-shrink:0}
.dp-tab {
  flex:1;padding:4px 0;font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-family:inherit;cursor:pointer;background:none;border:none;border-bottom:2px solid transparent;
  color:var(--text-secondary);transition:all .15s;
}
.dp-tab:hover{color:var(--text-primary)}
.dp-tab.active{color:var(--accent-active);border-bottom-color:var(--accent-active)}
.dp-list {
  flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:3px;padding:2px 0;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.dp-list::-webkit-scrollbar{width:3px}
.dp-list::-webkit-scrollbar-track{background:transparent}
.dp-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:3px}
.dp-list::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.25)}
.dp-hidden{display:none !important}
.dp-region {display:flex;align-items:center;gap:4px;font-size:9px;padding:2px 3px;border-radius:3px;transition:background .12s;flex-shrink:0}
.dp-region:hover{background:var(--bg-tertiary)}
.dp-region-label {display:flex;align-items:center;gap:4px;min-width:72px;max-width:72px;overflow:hidden}
.dp-flag {width:14px;height:10px;object-fit:cover;border-radius:1px;flex-shrink:0}
.dp-region-name {color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:9px}
.dp-region-bar-bg {flex:1;height:5px;background:var(--bg-primary);border-radius:3px;overflow:hidden}
.dp-region-bar {height:100%;border-radius:3px;transition:width .6s ease}
.dp-region-val {font-size:8px;color:var(--text-secondary);font-variant-numeric:tabular-nums;text-align:right}
.dp-gradient {display:flex;flex-direction:column;align-items:center;gap:3px;padding-top:6px;border-top:1px solid var(--border);flex-shrink:0}
.dp-gradient-bar {width:100%;height:5px;border-radius:3px;background:linear-gradient(to right,rgba(0,0,255,0),rgba(0,200,100,0.4),rgba(255,255,0,0.6),rgba(255,100,0,0.8),rgba(255,0,0,1))}
.dp-gradient-labels {display:flex;justify-content:space-between;width:100%;font-size:7px;color:var(--text-secondary)}
.dp-gradient-title {font-size:7px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-primary)}
@media(max-width:768px){
  .map-row{flex-direction:column}
  .demand-panel{width:100%;border-radius:var(--radius)}
  .map-col #map{height:400px}
}

.mfr-banner {
  max-width:1200px;margin:0 auto;padding:0 40px 4px;
}
.mfr-banner-inner {
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:12px 20px;
  background:linear-gradient(135deg, rgba(201,165,90,0.08), rgba(201,165,90,0.03));
  border:1px solid rgba(201,165,90,0.2);border-radius:var(--radius);
}
.mfr-banner-inner .banner-text {
  font-size:12px;color:var(--text-secondary);
}
.mfr-banner-inner .banner-text strong {
  color:var(--accent-active);
}

.filter-bar {
  display:flex;align-items:center;gap:4px;flex-wrap:nowrap;
}
.filter-btn {
  display:inline-flex;align-items:center;gap:5px;height:28px;
  padding:0 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-family:inherit;cursor:pointer;user-select:none;white-space:nowrap;
  background:var(--bg-tertiary);color:var(--text-secondary);
  border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s;
}
.filter-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}
.filter-btn.has-active{border-color:var(--border-hover);color:var(--text-primary)}
.filter-btn .arrow{font-size:8px;opacity:.5;transition:transform .15s}
.filter-btn.open .arrow{transform:rotate(180deg)}
.filter-sep{width:1px;height:20px;background:var(--border);margin:0 4px}
.filter-check {
  display:inline-flex;align-items:center;gap:5px;height:28px;
  padding:0 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-secondary);cursor:pointer;user-select:none;white-space:nowrap;
  background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all .15s;
}
.filter-check:hover{border-color:var(--border-hover);color:var(--text-primary)}
.filter-check input[type="checkbox"]{display:none}
.filter-check .check-box{width:14px;height:14px;flex-shrink:0;border:1px solid var(--border-hover);border-radius:3px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;transition:border-color .15s}
.filter-check:hover .check-box{border-color:var(--border-hover)}
.filter-check .check-box svg{width:10px;height:10px;opacity:0;transition:opacity .15s}
.filter-check input[type="checkbox"]:checked+.check-box{border-color:var(--border)}
.filter-check input[type="checkbox"]:checked+.check-box svg{opacity:1}
.filter-dropdown {
  display:none;
}
.filter-dropdown.open{display:block}
.filter-chips {
  display:flex;flex-wrap:wrap;gap:5px;
  padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);
}
.filter-chip {
  padding:4px 10px;font-size:10px;font-family:inherit;
  background:var(--bg-button);color:var(--text-secondary);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  cursor:pointer;transition:all .12s;user-select:none;
}
.filter-chip:hover{border-color:var(--border-hover);color:var(--text-primary)}
.filter-chip.active{border-color:var(--border-hover);color:var(--accent-active);background:var(--bg-tertiary)}
/* Custom numeric filter inputs (panel size, thickness) */
.filter-custom{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm)}
.filter-custom .flt-num{width:64px;padding:5px 8px;font-size:11px;font-family:inherit;background:var(--bg-well);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;-moz-appearance:textfield}
.filter-custom .flt-num::-webkit-inner-spin-button,.filter-custom .flt-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.filter-custom .flt-num:focus{border-color:var(--border-hover)}
.filter-custom .flt-x,.filter-custom .flt-unit-label{font-size:11px;color:var(--text-muted)}
.filter-custom .flt-unit{padding:5px 6px;font-size:11px;font-family:inherit;background:var(--bg-well);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;cursor:pointer}
.flt-hint{font-size:9px;color:var(--text-muted);padding:6px 14px 0;margin:0}
/* csel themed dropdown sized to fit the filter row */
.filter-custom .csel{width:62px;flex-shrink:0}
.filter-custom .csel-btn{height:auto;padding:5px 8px;font-size:11px}
.filter-custom .csel-btn::after{margin-left:4px;font-size:11px}
.filter-custom .csel-opt{font-size:11px}
.active-filters {
  display:none;align-items:center;gap:4px;flex-wrap:wrap;margin-top:2px;
}
.active-filters.visible{display:flex}
.filter-tag {
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;font-size:10px;color:var(--text-primary);
  background:var(--bg-tertiary);backdrop-filter:blur(4px);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  box-shadow:0 2px 6px rgba(0,0,0,0.4);
}
.filter-tag button {
  background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:12px;line-height:1;padding:0;
}
.filter-tag button:hover{color:#d08080}
.filter-clear {
  font-size:10px;color:var(--text-primary);cursor:pointer;border:none;
  background:rgba(26,25,22,0.92);backdrop-filter:blur(4px);
  font-family:inherit;text-decoration:underline;padding:3px 8px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  box-shadow:0 2px 6px rgba(0,0,0,0.4);
}
.filter-clear:hover{color:var(--text-primary);border-color:var(--border-hover)}

.quote-panel {
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.95);
  width:min(600px,calc(100% - 32px));
  background:var(--bg-secondary);border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 22px;z-index:1001;
  box-shadow:0 8px 40px rgba(0,0,0,0.5);transition:transform .2s ease, opacity .2s ease;
  opacity:0;pointer-events:none;
}
.quote-panel.open{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
.quote-panel h3{font-size:13px;font-weight:700;margin-bottom:10px}
.quote-list{max-height:180px;overflow-y:auto;margin-bottom:12px}
.quote-item {
  display:flex;align-items:center;gap:8px;
  padding:6px 0;border-bottom:1px solid var(--border);font-size:11px;
}
.quote-item:last-child{border-bottom:none}
.quote-item .qi-dist{margin-left:auto;font-size:10px;color:var(--text-muted)}
.quote-actions{display:flex;gap:8px;justify-content:flex-end}
.quote-actions button{font-family:inherit;cursor:pointer}
.pin-panel .opt-grid{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.pin-panel .opt-chip{padding:4px 10px;background:var(--bg-button);border:none;border-radius:var(--radius-sm);font-size:10px;color:var(--text-secondary);cursor:pointer;transition:all .15s;user-select:none}
.pin-panel .opt-chip:hover{background:var(--bg-tertiary);color:var(--text-primary)}
.pin-panel .opt-chip.active{background:var(--accent-dim);color:var(--accent-active)}
.pin-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-secondary);border:0.5px solid var(--border);border-radius:var(--radius-sm);z-index:10;margin-top:2px;padding:3px;box-shadow:0 6px 20px rgba(0,0,0,0.4);color-scheme:dark;scrollbar-color:rgba(255,255,255,0.15) transparent}
.pin-dropdown .dd-option{padding:5px 10px;font-size:10px;font-weight:500;border-radius:var(--radius-sm);color:var(--text-secondary);background:transparent;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .12s,color .12s;white-space:nowrap}
.pin-dropdown .dd-option:hover{background:var(--bg-tertiary);color:var(--text-primary)}
.pin-dropdown .dd-option .ral-swatch{width:16px;height:16px;border-radius:2px;border:1px solid rgba(255,255,255,0.1);flex-shrink:0}
.pin-ral-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--accent-dim);border:1px solid rgba(201,165,90,0.15);border-radius:var(--radius-sm);font-size:10px;color:var(--accent-active);cursor:default}
.pin-ral-tag .ral-x{cursor:pointer;font-size:12px;line-height:1;opacity:0.7}
.pin-ral-tag .ral-x:hover{opacity:1}
#pinFinishPicker{display:none;margin-top:4px;padding:8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm)}
#pinFinishPicker .opt-grid{margin-bottom:0}
.pin-panel,.contact-panel{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.95);
  width:min(480px,calc(100% - 32px));
  background:var(--bg-secondary);border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 22px;z-index:10000;
  box-shadow:0 8px 40px rgba(0,0,0,0.5);transition:transform .2s ease, opacity .2s ease;
  opacity:0;pointer-events:none;
}
.pin-panel{width:min(560px,calc(100% - 32px))}   /* wider — size + thickness + unit fit on one row */
.pin-panel.open,.contact-panel.open{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto}
.pin-panel h3,.contact-panel h3{font-size:13px;font-weight:700;margin-bottom:10px}
.pin-panel label{display:block;font-size:11px;color:var(--text-secondary);margin-bottom:4px}
.pin-panel input,.pin-panel textarea{
  width:100%;padding:8px 12px;font-size:12px;font-family:inherit;
  background:var(--bg-well);color:var(--text-secondary);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  outline:none;margin-bottom:8px;
}
.pin-panel input:focus,.pin-panel textarea:focus{border-color:var(--border-hover)}
input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type="number"]{-moz-appearance:textfield}
.pin-num::-webkit-inner-spin-button,.pin-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.pin-num{-moz-appearance:textfield}
.num-scrub{cursor:ew-resize}
.num-scrub:focus{cursor:text}
.pin-panel .consent-row{display:flex;align-items:flex-start;gap:8px;margin:8px 0}
.pin-panel .consent-row input[type="checkbox"]{display:none}
.pin-panel .consent-row .check-box{width:14px;height:14px;flex-shrink:0;margin-top:2px;border:1px solid var(--border-hover);border-radius:3px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s}
.pin-panel .consent-row .check-box:hover{border-color:var(--border-hover)}
.pin-panel .consent-row .check-box svg{width:10px;height:10px;opacity:0;transition:opacity .15s}
.pin-panel .consent-row input[type="checkbox"]:checked+.check-box{border-color:var(--border)}
.pin-panel .consent-row input[type="checkbox"]:checked+.check-box svg{opacity:1}
.pin-panel .consent-row span{font-size:11px;color:var(--text-secondary);line-height:1.5}
.contact-panel textarea{
  width:100%;padding:8px 12px;font-size:12px;font-family:inherit;
  background:var(--bg-well);color:var(--text-primary);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  outline:none;resize:vertical;margin-bottom:8px;
}
.btn-ghost {
  padding:6px 14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  background:transparent;color:var(--text-secondary);
  border:1px solid var(--border);border-radius:var(--radius-sm);
}
.btn-ghost:hover{border-color:var(--border-hover)}

.mfr-list {
  max-width:1200px;margin:0 auto;padding:0 40px 60px;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;
}
.mfr-card {
  background:var(--bg-secondary);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 16px;transition:border-color .2s;
  font-size:12px;
}
.mfr-card:hover{border-color:var(--border-hover)}
.social-links{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.social-link{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text-secondary);transition:color .12s}
.social-link:hover{color:var(--text-primary)}
.social-link svg{width:14px;height:14px;flex-shrink:0;fill:currentColor}
.social-link.sl-web svg{fill:var(--accent-active)}

/* Portfolio strip in the card + full-screen lightbox */
.mfr-gallery-strip{display:flex;gap:4px;margin-top:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}
.mfr-gallery-thumb{width:56px;height:42px;object-fit:cover;border-radius:4px;border:1px solid var(--border);cursor:pointer;flex-shrink:0;transition:border-color .12s}
.mfr-gallery-thumb:hover{border-color:var(--accent-active)}
.mfr-lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,0.85);display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.mfr-lightbox.open{display:flex}
.mfr-lightbox img{max-width:90vw;max-height:90vh;border-radius:6px;box-shadow:0 10px 40px rgba(0,0,0,0.5)}

.btn-sm{padding:5px 14px;font-size:10px}
.btn-green{background:#4CAF50;border-color:#4CAF50;color:#fff}
.btn-green:hover{background:#43A047;border-color:#43A047;color:#fff}

@media(max-width:640px){
  .page-header{padding:72px 16px 20px}
  .map-wrapper{padding:0 16px 16px}
  #map{height:420px}
  .map-toolbar{left:50%;transform:translateX(-50%);max-width:calc(100% - 20px)}
  .map-search-row input{min-width:100px}
  .mfr-list{padding:16px;grid-template-columns:1fr}
}
