/* BEVIL Store Locator — v7 airy */
:root{--bsl-primary:#c0392b;--bsl-blue:#2563eb;--bsl-blue-light:#eff6ff;--bsl-text:#1e293b;--bsl-muted:#64748b;--bsl-faint:#94a3b8;--bsl-border:#e2e8f0;--bsl-bg:#f8fafc;--bsl-card:#fff;--bsl-radius:12px;--bsl-pad:36px}
@media(max-width:680px){:root{--bsl-pad:20px}}

#bevil-store-locator{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;color:var(--bsl-text);width:100%;max-width:1100px;margin:0 auto;border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06),0 8px 32px rgba(0,0,0,.06);background:var(--bsl-card)}
#bevil-store-locator,#bevil-store-locator *{box-sizing:border-box}

/* ═══ SEARCH ═══ */
.bsl-search{padding:32px var(--bsl-pad) 28px;background:#f0f2f5;border-bottom:1px solid var(--bsl-border)}
.bsl-search-row1{margin-bottom:16px}
.bsl-search-row2{display:flex;gap:14px;align-items:stretch}
@media(max-width:680px){.bsl-search-row2{flex-wrap:wrap;gap:12px}.bsl-search-row2 .bsl-btn{width:100%}}

/* Fields */
.bsl-field{position:relative}
.bsl-field-product{width:100%}
.bsl-field-zip{width:220px;flex-shrink:0}
@media(max-width:680px){.bsl-field-zip{width:100%;flex:1}}
.bsl-field input{width:100%;height:52px;padding:0 20px;border:2px solid #dde1e8;border-radius:var(--bsl-radius);font-size:.95rem;background:#fff;color:var(--bsl-text);outline:none;transition:all .2s;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.bsl-field input:focus{border-color:var(--bsl-blue);box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.bsl-field input::placeholder{color:#b0b8c8;font-weight:400}

/* Radius */
.bsl-radius select{height:52px;padding:0 36px 0 16px;border:2px solid #dde1e8;border-radius:var(--bsl-radius);font-size:.92rem;background:#fff;color:var(--bsl-text);outline:none;cursor:pointer;transition:border .2s;box-shadow:0 1px 2px rgba(0,0,0,.04);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.bsl-radius select:focus{border-color:var(--bsl-blue)}

/* Button */
.bsl-btn{height:52px;padding:0 36px;background:var(--bsl-text);color:#fff;border:none;border-radius:var(--bsl-radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.bsl-btn:hover{background:#0f172a;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.bsl-btn:active{transform:scale(.98)}
.bsl-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.bsl-btn .bsl-spinner{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:bsl-spin .6s linear infinite}
.bsl-btn.loading .bsl-spinner{display:inline-block}
.bsl-btn.loading span{display:none}
@keyframes bsl-spin{to{transform:rotate(360deg)}}

/* ═══ AUTOCOMPLETE ═══ */
.bsl-autocomplete{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--bsl-border);border-radius:14px;max-height:300px;overflow-y:auto;z-index:9999;display:none;box-shadow:0 20px 60px rgba(0,0,0,.12)}
.bsl-autocomplete.open{display:block}
.bsl-ac-item{padding:14px 20px;font-size:.9rem;color:var(--bsl-text);cursor:pointer;border-bottom:1px solid #f7f7f7;transition:background .1s;display:flex;align-items:center;justify-content:space-between;gap:14px}
.bsl-ac-item:first-child{border-radius:14px 14px 0 0}
.bsl-ac-item:last-child{border:none;border-radius:0 0 14px 14px}
.bsl-ac-item:hover,.bsl-ac-item.active{background:var(--bsl-blue-light)}
.bsl-ac-match{color:var(--bsl-blue);font-weight:700}
.bsl-ac-count{font-size:.72rem;color:var(--bsl-faint);white-space:nowrap;flex-shrink:0;background:#f1f5f9;padding:4px 10px;border-radius:20px;font-weight:500}
.bsl-ac-empty{color:var(--bsl-faint);cursor:default}
.bsl-ac-empty:hover{background:transparent}

/* ═══ SELECTED BADGE ═══ */
.bsl-selected{display:flex;align-items:center;gap:12px;height:52px;padding:0 20px;background:var(--bsl-blue-light);border:2px solid #bfdbfe;border-radius:var(--bsl-radius);width:100%;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.bsl-selected-name{font-size:.92rem;color:var(--bsl-blue);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.bsl-selected-clear{background:none;border:none;color:var(--bsl-faint);font-size:1.2rem;cursor:pointer;padding:4px;line-height:1;transition:color .15s;border-radius:6px}
.bsl-selected-clear:hover{color:var(--bsl-primary);background:rgba(192,57,43,.06)}

/* ═══ BODY LAYOUT ═══ */
.bsl-body{display:flex;height:520px;background:var(--bsl-card)}
@media(max-width:680px){.bsl-body{flex-direction:column-reverse;height:auto}.bsl-map{height:360px!important}.bsl-list{max-height:320px}}
.bsl-map{flex:1;min-height:300px}
.bsl-list{width:400px;overflow-y:auto;background:var(--bsl-bg);border-left:1px solid #eef0f3;scrollbar-gutter:stable}
@media(max-width:680px){.bsl-list{width:100%;border-left:none;border-top:1px solid #eef0f3}}
.bsl-list::-webkit-scrollbar{width:5px}
.bsl-list::-webkit-scrollbar-track{background:transparent}
.bsl-list::-webkit-scrollbar-thumb{background:#d0d5dd;border-radius:3px}
.bsl-list::-webkit-scrollbar-thumb:hover{background:#b0b8c4}

/* ═══ LIST HEADER ═══ */
.bsl-list-header{padding:24px var(--bsl-pad) 18px;background:var(--bsl-card);border-bottom:1px solid #eef0f3;position:sticky;top:0;z-index:10}
.bsl-list-header h3{font-size:.9rem;font-weight:600;color:var(--bsl-text);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bsl-list-header .bsl-count{font-size:.78rem;color:var(--bsl-muted);margin-top:8px;font-weight:400}

/* ═══ STORE CARD ═══ */
.bsl-store{padding:22px var(--bsl-pad);cursor:pointer;transition:background .15s;display:flex;gap:16px;align-items:flex-start;border-bottom:1px solid #eef0f3}
.bsl-store:last-child{border:none}
.bsl-store:hover{background:#fff}
.bsl-store.active{background:var(--bsl-blue-light)}
.bsl-store-num{width:32px;height:32px;background:var(--bsl-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;flex-shrink:0;margin-top:2px}
.bsl-store-info{flex:1;min-width:0}
.bsl-store-name{font-size:.94rem;font-weight:600;color:var(--bsl-text);margin-bottom:6px;line-height:1.45}
.bsl-store-addr{font-size:.8rem;color:var(--bsl-faint);margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bsl-store-city{font-size:.82rem;color:var(--bsl-muted);line-height:1.4}
.bsl-store-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:10px}
.bsl-store-dist{font-size:.82rem;color:var(--bsl-blue);font-weight:600}
.bsl-store-dir{font-size:.76rem;color:#fff;text-decoration:none;padding:8px 16px;border:none;border-radius:8px;transition:all .15s;background:var(--bsl-text);font-weight:600}
.bsl-store-dir:hover{background:#0f172a}

/* ═══ EMPTY STATE ═══ */
.bsl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:56px var(--bsl-pad);min-height:200px}
.bsl-empty svg{width:48px;height:48px;opacity:.1;margin-bottom:24px}
.bsl-empty-title{font-size:1.05rem;font-weight:600;color:var(--bsl-muted);margin-bottom:10px}
.bsl-empty-text{font-size:.88rem;line-height:2;color:var(--bsl-faint)}

/* ═══ TOAST ═══ */
.bsl-toast{position:fixed;top:24px;left:50%;transform:translateX(-50%);background:var(--bsl-text);color:#fff;padding:12px 24px;border-radius:var(--bsl-radius);font-size:.86rem;font-weight:500;z-index:10000;box-shadow:0 8px 32px rgba(0,0,0,.15);animation:bsl-fadein .2s ease}
@keyframes bsl-fadein{from{opacity:0;transform:translateX(-50%) translateY(-6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ═══ MAP MARKERS ═══ */
.bsl-marker{display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid #fff;color:#fff;font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.18);cursor:pointer;transition:transform .15s}
.bsl-marker:hover{transform:scale(1.15)}
.bsl-user-marker{width:14px;height:14px;background:var(--bsl-blue);border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 6px rgba(37,99,235,.1),0 2px 6px rgba(0,0,0,.12);animation:bsl-pulse 3s ease-in-out infinite}
@keyframes bsl-pulse{0%,100%{box-shadow:0 0 0 6px rgba(37,99,235,.1),0 2px 6px rgba(0,0,0,.12)}50%{box-shadow:0 0 0 16px rgba(37,99,235,.03),0 2px 6px rgba(0,0,0,.12)}}

/* ═══ MAP POPUP ═══ */
.bsl-popup{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;min-width:220px;line-height:1.6}
.bsl-popup-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--bsl-primary);color:#fff;border-radius:50%;font-size:.68rem;font-weight:700;margin-right:8px;vertical-align:middle}
.bsl-popup-name{font-size:.94rem;font-weight:600;color:var(--bsl-text);margin-bottom:8px}
.bsl-popup-addr{font-size:.8rem;color:var(--bsl-faint);margin-bottom:4px}
.bsl-popup-city{font-size:.82rem;color:var(--bsl-muted)}
.bsl-popup-dist{font-size:.82rem;color:var(--bsl-blue);font-weight:600;margin-top:12px}
.bsl-popup-dir{display:inline-block;margin-top:14px;font-size:.78rem;color:#fff;background:var(--bsl-text);padding:8px 20px;border-radius:8px;text-decoration:none;font-weight:600;transition:background .15s}
.bsl-popup-dir:hover{background:#0f172a}

/* ═══ LEAFLET OVERRIDES ═══ */
#bevil-store-locator .leaflet-popup-content-wrapper{border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.1);padding:0;overflow:hidden;border:none}
#bevil-store-locator .leaflet-popup-content{margin:18px 20px}
#bevil-store-locator .leaflet-popup-tip{box-shadow:0 2px 8px rgba(0,0,0,.06)}
