/* ========================================================
   WooCommerce Product Store Locator v2 – Frontend Styles
   ======================================================== */

:root {
    --wpsl-primary:    #e74c3c;
    --wpsl-primary-dk: #c0392b;
    --wpsl-sidebar-w:  380px;
    --wpsl-radius:     10px;
    --wpsl-shadow:     0 3px 14px rgba(0,0,0,.12);
    --wpsl-open:       #27ae60;
    --wpsl-closed:     #e74c3c;
    --wpsl-temp:       #f39c12;
}

#wpsl-wrapper {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 14px;
    color: #2d3436;
    position: relative;
    background: #f7f8fa;
    border-radius: var(--wpsl-radius);
    padding: 14px;
}

/* ── Search bar ──────────────────────────────────────────── */
#wpsl-search-bar {
    background: #fff;
    border-radius: var(--wpsl-radius);
    box-shadow: var(--wpsl-shadow);
    padding: 12px 14px;
    margin-bottom: 12px;
}

#wpsl-search-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

#wpsl-product-search-wrap {
    position: relative;
    flex: 1 1 280px;
}

.wpsl-search-icon {
    position: absolute;
    left: 11px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 15px;
    pointer-events: none;
    opacity: .6;
}

#wpsl-product-input {
    width: 100%;
    padding: 10px 36px 10px 36px;
    border: 2px solid #e0e0e0;
    border-radius: 7px;
    font-size: 14px;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
    background: #fafafa;
}

#wpsl-product-input:focus {
    border-color: var(--wpsl-primary);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(231,76,60,.12);
}

#wpsl-clear-btn {
    position: absolute;
    right: 9px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: #aaa;
    font-size: 16px;
    display: none;
    padding: 4px;
    line-height: 1;
}
#wpsl-clear-btn:hover { color: #333; }

/* Autocomplete */
#wpsl-autocomplete-list {
    position: absolute;
    top: calc(100% + 5px);
    left: 0; right: 0;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 6px 24px rgba(0,0,0,.13);
    list-style: none;
    margin: 0;
    padding: 0;
    z-index: 9999;
    max-height: 300px;
    overflow-y: auto;
    display: none;
}

#wpsl-autocomplete-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 13px;
    cursor: pointer;
    border-bottom: 1px solid #f4f4f4;
    transition: background .12s;
}
#wpsl-autocomplete-list li:last-child { border-bottom: none; }
#wpsl-autocomplete-list li:hover,
#wpsl-autocomplete-list li.active { background: #fff5f5; }
#wpsl-autocomplete-list li img { width:38px;height:38px;object-fit:cover;border-radius:5px;flex-shrink:0; }
.wpsl-ac-name  { font-weight: 600; font-size: 13px; }
.wpsl-ac-price { color: var(--wpsl-primary); font-size: 12px; margin-top: 1px; }

/* Radius controls */
#wpsl-radius-wrap { display: flex; gap: 6px; align-items: center; }

#wpsl-radius-select {
    padding: 9px 10px;
    border: 2px solid #e0e0e0;
    border-radius: 7px;
    font-size: 13px;
    background: #fafafa;
    outline: none;
    cursor: pointer;
}

#wpsl-locate-btn {
    background: #fafafa;
    border: 2px solid #e0e0e0;
    border-radius: 7px;
    padding: 7px 11px;
    cursor: pointer;
    font-size: 16px;
    transition: border-color .2s, background .2s;
}
#wpsl-locate-btn:hover { border-color: var(--wpsl-primary); background: #fff5f5; }

#wpsl-search-btn {
    background: var(--wpsl-primary);
    color: #fff;
    border: none;
    border-radius: 7px;
    padding: 10px 22px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background .2s, transform .1s, box-shadow .2s;
    box-shadow: 0 2px 8px rgba(231,76,60,.3);
    white-space: nowrap;
}
#wpsl-search-btn:hover  { background: var(--wpsl-primary-dk); box-shadow: 0 4px 12px rgba(231,76,60,.4); }
#wpsl-search-btn:active { transform: scale(.97); }

/* ── Layout ──────────────────────────────────────────────── */
#wpsl-layout {
    display: flex;
    border-radius: var(--wpsl-radius);
    overflow: hidden;
    box-shadow: var(--wpsl-shadow);
    background: #fff;
}

/* ── Sidebar ─────────────────────────────────────────────── */
#wpsl-sidebar {
    width: var(--wpsl-sidebar-w);
    flex-shrink: 0;
    background: #fff;
    display: flex;
    flex-direction: column;
    border-right: 1px solid #eee;
    overflow: hidden;
}

#wpsl-sidebar-header {
    padding: 10px 14px;
    background: #f8f9fa;
    border-bottom: 1px solid #eee;
    font-weight: 700;
    font-size: 12px;
    color: #666;
    text-transform: uppercase;
    letter-spacing: .5px;
}

#wpsl-store-list,
#wpsl-store-detail { flex: 1; overflow-y: auto; }

/* ── Store card (list view) ──────────────────────────────── */
.wpsl-store-card {
    display: flex;
    gap: 11px;
    padding: 13px 14px;
    border-bottom: 1px solid #f0f0f0;
    cursor: pointer;
    transition: background .15s;
    position: relative;
}
.wpsl-store-card:hover  { background: #fff8f7; }
.wpsl-store-card.active { background: #fff3f2; border-left: 3px solid var(--wpsl-primary); padding-left: 11px; }

.wpsl-store-thumb {
    width: 54px;
    height: 54px;
    object-fit: cover;
    border-radius: 7px;
    flex-shrink: 0;
}
.wpsl-store-thumb-ph {
    width: 54px;
    height: 54px;
    border-radius: 7px;
    background: linear-gradient(135deg,#f5f5f5,#e8e8e8);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
}

.wpsl-card-body    { flex: 1; min-width: 0; }
.wpsl-card-name    { font-weight: 700; font-size: 13px; margin-bottom: 2px; white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.wpsl-card-address { font-size: 11px; color: #888; margin-bottom: 5px; }
.wpsl-card-meta    { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.wpsl-badge        { font-size: 11px; padding: 2px 7px; border-radius: 20px; font-weight: 600; }
.wpsl-badge-dist   { background: var(--wpsl-primary); color: #fff; }
.wpsl-badge-open   { background: #e8f8f0; color: var(--wpsl-open); }
.wpsl-badge-closed { background: #fdecea; color: var(--wpsl-closed); }
.wpsl-badge-temp   { background: #fef5e4; color: var(--wpsl-temp); }
.wpsl-badge-prods  { background: #f0f0f0; color: #555; }
.wpsl-card-stars   { display: flex; gap: 1px; align-items: center; }
.wpsl-star         { color: #f39c12; font-size: 12px; }
.wpsl-star-empty   { color: #ddd; font-size: 12px; }
.wpsl-card-rating-txt { font-size: 11px; color: #888; margin-left: 3px; }

/* ── Empty / loading ─────────────────────────────────────── */
.wpsl-msg { text-align: center; padding: 40px 20px; color: #888; }
.wpsl-msg-icon { font-size: 42px; margin-bottom: 10px; }
.wpsl-msg p { margin: 4px 0; font-size: 13px; }
.wpsl-spinner {
    display: inline-block;
    width: 30px; height: 30px;
    border: 3px solid #eee;
    border-top-color: var(--wpsl-primary);
    border-radius: 50%;
    animation: wpsl-spin .7s linear infinite;
    margin-bottom: 10px;
}
@keyframes wpsl-spin { to { transform: rotate(360deg); } }

/* ── Map ─────────────────────────────────────────────────── */
#wpsl-map { flex: 1; min-height: 400px; z-index: 1; }

/* ── Marker ──────────────────────────────────────────────── */
.wpsl-marker {
    background: var(--wpsl-primary);
    border: 2.5px solid #fff;
    border-radius: 50% 50% 50% 0;
    transform: rotate(-45deg);
    box-shadow: 0 3px 8px rgba(0,0,0,.3);
    width: 34px; height: 34px;
    transition: background .2s, transform .2s;
    cursor: pointer;
}
.wpsl-marker.active   { background: #2c3e50; transform: rotate(-45deg) scale(1.35); }
.wpsl-marker.temp     { background: var(--wpsl-temp); }
.wpsl-marker-inner    { transform: rotate(45deg); display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:15px;color:#fff; }

/* ── Map popup ───────────────────────────────────────────── */
.leaflet-popup-content-wrapper { border-radius:10px!important;box-shadow:0 6px 20px rgba(0,0,0,.15)!important;padding:0!important; }
.leaflet-popup-content { margin:0!important;width:auto!important; }
.wpsl-popup { min-width:220px;max-width:280px;padding:14px 16px;font-family:inherit; }
.wpsl-popup-header { display:flex;align-items:center;gap:10px;margin-bottom:10px; }
.wpsl-popup-logo { width:40px;height:40px;object-fit:contain;border:1px solid #eee;border-radius:5px;flex-shrink:0; }
.wpsl-popup-name { font-weight:700;font-size:14px;line-height:1.2; }
.wpsl-popup-status { font-size:11px;font-weight:600;margin-top:2px; }
.wpsl-popup-row { font-size:12px;color:#555;margin-bottom:4px;display:flex;gap:6px;align-items:flex-start; }
.wpsl-popup-row span:first-child { flex-shrink:0;width:16px;text-align:center; }
.wpsl-popup-actions { display:flex;gap:6px;margin-top:10px; }
.wpsl-popup-btn { flex:1;text-align:center;padding:6px 8px;border-radius:5px;font-size:12px;font-weight:600;text-decoration:none;cursor:pointer; }
.wpsl-popup-btn-primary { background:var(--wpsl-primary);color:#fff; }
.wpsl-popup-btn-primary:hover { background:var(--wpsl-primary-dk);color:#fff; }
.wpsl-popup-btn-secondary { background:#f0f0f0;color:#333; }
.wpsl-popup-btn-secondary:hover { background:#e0e0e0;color:#333; }

/* ── Detail panel (sidebar) ──────────────────────────────── */
#wpsl-store-detail { padding: 0; }

.wpsl-detail-back {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 14px;
    background: #f8f9fa;
    border-bottom: 1px solid #eee;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: var(--wpsl-primary);
    transition: background .15s;
    position: sticky;
    top: 0;
    z-index: 10;
}
.wpsl-detail-back:hover { background: #fff3f2; }

.wpsl-detail-hero {
    padding: 16px 14px 12px;
    border-bottom: 1px solid #f0f0f0;
}

.wpsl-detail-top {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 10px;
}

.wpsl-detail-logo {
    width: 58px;
    height: 58px;
    object-fit: contain;
    border: 1px solid #eee;
    border-radius: 8px;
    flex-shrink: 0;
    background: #fafafa;
    padding: 4px;
}

.wpsl-detail-logo-ph {
    width: 58px;
    height: 58px;
    border-radius: 8px;
    background: linear-gradient(135deg,#f5f5f5,#e8e8e8);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    flex-shrink: 0;
}

.wpsl-detail-name  { font-size: 17px; font-weight: 800; margin-bottom: 3px; line-height: 1.2; }
.wpsl-detail-type  { font-size: 11px; color: #888; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 5px; }
.wpsl-detail-stars { display: flex; align-items: center; gap: 5px; }
.wpsl-detail-stars .wpsl-star { font-size: 14px; }
.wpsl-rating-count { font-size: 12px; color: #888; }

/* Status pill */
.wpsl-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 20px;
    margin-top: 6px;
}
.wpsl-status-pill .wpsl-dot { width: 7px; height: 7px; border-radius: 50%; }
.status-open    { background: #e8f8f0; color: var(--wpsl-open);   }
.status-open    .wpsl-dot { background: var(--wpsl-open); }
.status-closed  { background: #fdecea; color: var(--wpsl-closed); }
.status-closed  .wpsl-dot { background: var(--wpsl-closed); }
.status-temp    { background: #fef5e4; color: var(--wpsl-temp);   }
.status-temp    .wpsl-dot { background: var(--wpsl-temp); }

/* Detail description */
.wpsl-detail-desc {
    font-size: 13px;
    color: #666;
    line-height: 1.5;
    padding: 10px 14px;
    border-bottom: 1px solid #f0f0f0;
}

/* Action buttons */
.wpsl-action-btns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    padding: 12px 14px;
    border-bottom: 1px solid #f0f0f0;
}

.wpsl-action-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 10px 8px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: background .15s, transform .1s;
}
.wpsl-action-btn:active { transform: scale(.96); }
.wpsl-action-btn span:first-child { font-size: 20px; }

.wpsl-btn-call       { background: #e8f8f0; color: #219a52; }
.wpsl-btn-call:hover { background: #d5f0e3; color: #219a52; text-decoration: none; }
.wpsl-btn-wa         { background: #e7f8ed; color: #128c7e; }
.wpsl-btn-wa:hover   { background: #d1f0e0; color: #128c7e; text-decoration: none; }
.wpsl-btn-dir        { background: #e8f0ff; color: #1a5eb8; }
.wpsl-btn-dir:hover  { background: #d5e5ff; color: #1a5eb8; text-decoration: none; }
.wpsl-btn-web        { background: #f4f0ff; color: #7c3aed; }
.wpsl-btn-web:hover  { background: #e9e0ff; color: #7c3aed; text-decoration: none; }

/* Detail section */
.wpsl-detail-section {
    padding: 12px 14px;
    border-bottom: 1px solid #f0f0f0;
}

.wpsl-section-label {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: #999;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Contact rows */
.wpsl-contact-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 5px 0;
    font-size: 13px;
}
.wpsl-contact-row .wpsl-ci { font-size: 16px; width: 22px; text-align: center; }
.wpsl-contact-row a { color: #333; text-decoration: none; }
.wpsl-contact-row a:hover { color: var(--wpsl-primary); text-decoration: underline; }

/* Social */
.wpsl-social-row { display: flex; gap: 8px; padding: 4px 0; }
.wpsl-social-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    transition: opacity .15s;
}
.wpsl-social-btn:hover { opacity: .82; text-decoration: none; }
.wpsl-social-fb { background: #1877f2; color: #fff; }
.wpsl-social-ig { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color: #fff; }

/* Hours table */
.wpsl-hours-list { display: flex; flex-direction: column; gap: 3px; }
.wpsl-hours-row  { display: flex; justify-content: space-between; font-size: 13px; padding: 3px 0; }
.wpsl-hours-row.today { font-weight: 700; color: #2d3436; }
.wpsl-hours-row .day-name { color: #555; width: 100px; }
.wpsl-hours-row .day-time { color: #333; }
.wpsl-hours-row .day-closed { color: #aaa; font-style: italic; }

/* Amenities */
.wpsl-amenities-list { display: flex; flex-wrap: wrap; gap: 6px; }
.wpsl-amenity-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #f4f5f7;
    padding: 5px 10px;
    border-radius: 20px;
    font-size: 12px;
    color: #444;
    font-weight: 500;
}

/* Insurance / services tags */
.wpsl-tags-list { display: flex; flex-wrap: wrap; gap: 6px; }
.wpsl-tag-chip {
    background: #edf7ff;
    color: #1a6fa0;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}
.wpsl-svc-chip {
    background: #f0fff4;
    color: #276749;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

/* ── Reviews ─────────────────────────────────────────────── */
.wpsl-review-card {
    padding: 10px 0;
    border-bottom: 1px solid #f4f4f4;
}
.wpsl-review-card:last-of-type { border-bottom: none; }
.wpsl-review-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.wpsl-reviewer-name { font-weight: 700; font-size: 13px; }
.wpsl-review-date   { font-size: 11px; color: #aaa; }
.wpsl-review-text   { font-size: 13px; color: #555; line-height: 1.5; margin-top: 4px; }

/* Review form */
.wpsl-review-form { margin-top: 12px; padding-top: 12px; border-top: 1px solid #f0f0f0; }
.wpsl-review-form label { display: block; font-size: 12px; font-weight: 700; color: #555; margin-bottom: 4px; }
.wpsl-review-form input,
.wpsl-review-form textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 13px;
    box-sizing: border-box;
    margin-bottom: 8px;
    font-family: inherit;
}
.wpsl-review-form textarea { resize: vertical; min-height: 70px; }
.wpsl-star-picker { display: flex; gap: 4px; margin-bottom: 8px; cursor: pointer; }
.wpsl-star-pick   { font-size: 24px; color: #ddd; transition: color .1s; }
.wpsl-star-pick.selected,
.wpsl-star-pick.hover { color: #f39c12; }
.wpsl-review-submit {
    background: var(--wpsl-primary);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    width: 100%;
}
.wpsl-review-submit:hover { background: var(--wpsl-primary-dk); }
.wpsl-review-msg { font-size: 12px; margin-top: 6px; padding: 6px 10px; border-radius: 5px; }
.wpsl-review-msg.success { background: #e8f8f0; color: var(--wpsl-open); }
.wpsl-review-msg.error   { background: #fdecea; color: var(--wpsl-closed); }

/* ── Directions overlay on map ───────────────────────────── */
#wpsl-directions-bar {
    display: none;
    position: absolute;
    bottom: 20px;
    left: calc(var(--wpsl-sidebar-w) + 20px);
    right: 20px;
    background: #fff;
    border-radius: 8px;
    box-shadow: var(--wpsl-shadow);
    padding: 10px 14px;
    z-index: 9997;
    font-size: 13px;
    display: none;
    align-items: center;
    gap: 10px;
}
#wpsl-directions-bar.visible { display: flex; }
#wpsl-directions-bar .dir-info { flex: 1; }
#wpsl-directions-bar .dir-dist { font-weight: 700; color: var(--wpsl-primary); }
#wpsl-directions-close { background: none; border: none; cursor: pointer; font-size: 18px; color: #aaa; padding: 0; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 768px) {
    #wpsl-wrapper     { padding: 8px; }
    #wpsl-layout      { flex-direction: column-reverse; }
    #wpsl-sidebar     { width: 100%; max-height: 300px; border-right: none; border-top: 1px solid #eee; }
    #wpsl-map         { height: 280px !important; }
    #wpsl-action-btns { grid-template-columns: 1fr 1fr; }
    #wpsl-directions-bar { left: 10px; right: 10px; bottom: 10px; }
}
