/* Container and layout */
.fr-wrapper { display: grid; gap: 18px; }
.fr-header { display:flex; align-items: flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.fr-title { line-height: 1.1; margin: 0;}
.fr-title span.block {
    font-size: 12.5vw;
    line-height: 0.88;
    text-transform: uppercase;
    font-family: var(--font-family-narrow)!important;
    margin: 0;
}
@media (min-width: 1024px) {
    .fr-title span.block {
        font-size: 7.98vw;
    }
}

.fr-search { position: relative; display:flex; overflow: hidden; padding-bottom: 0.75rem; }
.fr-search input {
  border: 2px solid #FFF;
  background: #1F1F1F;
  display: flex;
  width:100%;
  max-width: 253px;
  height: 50px;
  padding: 1px 0 0 21px;
  justify-content: flex-end;
  align-items: center;
  gap: 34px;
 }
.fr-search input:focus-visible {
  outline: none
}
.fr-search button {
  display: flex;
  width: 54px;
  height: 49px;
  padding: 6px 8px 5px 8px;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  background: var(--color-white);
}

/* Suggestions dropdown */
.fr-suggestions { position: absolute; top: 100%; left: 0; right: 0; z-index: 10000; background: #0b0b0b; border: 1px solid #222; max-height: 260px; overflow-y: auto; box-shadow: 0 6px 12px rgba(0,0,0,.3); }
.fr-suggestion { display: flex; align-items: center; gap: 8px; padding: 10px 12px; cursor: pointer; border-bottom: 1px solid #111; }
.fr-suggestion:last-child { border-bottom: 0; }
.fr-suggestion:hover, .fr-suggestion[aria-selected='true'] { background: #111; }
.fr-suggestion-title { font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.fr-suggestion-address { color: #b3b3b3; font-size: .9rem; }
.fr-suggestion-empty { padding: 12px; color: #b3b3b3; }

.fr-map { width: 100%; height: 420px; background: #000; z-index:99;}
/* Ensure black background under tiles while map/tiles load */
.fr-map.leaflet-container { background: #000 !important; }
.fr-list-header .fr-divider { border-top: 1px dotted var(--color-primary, #E3FF6E); }

/* List grid */
.fr-list { margin-top:2rem;display:grid; grid-template-columns: repeat(1,minmax(0,1fr)); gap: 1.25rem; }
@media (min-width: 640px) { .fr-list { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (min-width: 1024px) { .fr-list { grid-template-columns: repeat(3,minmax(0,1fr)); } }

.fr-list-item { border: 2px solid #5e5e5e; background: #1e1e1e; padding: 28px 23px 26px 23px; border-radius:0.75rem;transition: transform .2s ease, border-color .2s ease; cursor: pointer; }
.fr-list-item:hover { 
  transform: translateY(-2px); 
  background:linear-gradient(var(--color-dark), var(--color-dark)) padding-box, var(--Frutful-Gradient) border-box;  
  border: 2px solid transparent!important;
  text-decoration: none; 
}
@media (min-width: 1024px) { .fr-list-item { padding: 28px 43px 26px 43px;} }

.fr-list-hd { display:flex; flex-direction:column; gap:6px; }
.fr-list-title { font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.fr-list-address { color:#b3b3b3; font-size:.95rem; display:inline-flex; align-items:start; gap:6px; }
.fr-list-actions { margin-top: 12px; display:flex; gap:8px; }

.fr-actions { display:flex; justify-content:center; margin-top: 8px; }
.fr-actions .button.button-white { 
  text-transform: uppercase;
  background:linear-gradient(var(--color-secondary), var(--color-secondary)); 
  color:#1e1e1e; 
  border:1px solid #000; 
  padding:10px 16px; 
  text-decoration:none; }
.fr-actions .button.button-white:hover { 
    background:var(--Frutful-Gradient) padding-box, var(--Frutful-Gradient) border-box;  
    border: 1px solid transparent!important;
    color: var(--color-dark)!important;
    text-decoration: none;
}
/* Popup card */
.fr-popup .leaflet-popup-content { margin:0; background:#1f1f1f;border-radius:12px; }
.fr-card { min-width: 260px; max-width: 320px; color:#fff;padding:1rem; }
.fr-card-hd { display:flex; gap:10px; align-items:flex-start; }
.fr-logo { width:48px; height:auto; object-fit:contain; background:#fff; padding:2px; border:1px solid #eee; }
.fr-card-title { font-weight:700; text-transform:uppercase; margin-bottom:2px; }
.fr-address { color:#fff; font-size: .95rem; }
.fr-hours { margin-top:8px; font-size: .9rem; color:#222; white-space: pre-line; }
.fr-card-actions { margin-top:10px; }

.fr-btn.button-primary { display:inline-block; padding:8px 20px; background:#000; color:#fff; text-decoration:none; border:2px solid #fff; margin-top:1rem; }
.fr-btn:hover { background:#333; }

.leaflet-popup-content-wrapper, .leaflet-popup-tip {
    background: var(--Frutful-Gradient);
    padding:2px;    
    box-shadow: 0 3px 14px rgba(0,0,0,0.4);
    color: white;
}
.leaflet-container a.leaflet-popup-close-button {
    position: absolute;
    top: 7px;
    right: 7px;
    color: #fff;
}
/* Marker divIcon hover is handled via JS by updating fill */
.fr-pin svg { display:block; filter: drop-shadow(0 2px 4px rgba(0,0,0,.6)); }
