/*
 * BridgeFly Pro — Listing Layout v6.0
 *
 * This is the ONLY CSS file for listing page structure.
 * It is loaded as a real <link> stylesheet via wp_enqueue_style('mbp-listing').
 *
 * HOW IT WORKS:
 * - All dynamic values (colors, radii, sizes from Card Design) are CSS custom
 *   properties (--sl-acc, --dl-btn-bg, --pl-card-w …) set by a tiny inline
 *   <style> block inside each shortcode template (~500 chars). That tiny block
 *   is so small that no caching/page-builder can meaningfully break it.
 * - All structural rules use !important so no inline style set by card-styler
 *   JS or page-builder hydration can override the grid/flex layout.
 * - [data-mbp-listing] is the sentinel attribute. The root div of every listing
 *   template carries it, so all rules below are strictly scoped.
 */

/* ════════════════════════════════════════════════════════════════════════
   ANTI-FOUC — hide until listing root is ready, then fade in
════════════════════════════════════════════════════════════════════════ */
[data-mbp-listing] {
    font-family: 'DM Sans', 'Segoe UI', system-ui, -apple-system, sans-serif;
    color: #1e293b;
    opacity: 0;
    transition: opacity .15s ease;
    -webkit-font-smoothing: antialiased;
}
[data-mbp-listing].mbp-ready { opacity: 1 !important; }
[data-mbp-listing] * { box-sizing: border-box; }

/* ── JS-proof width guard ── */
[data-mbp-listing] .sl-card,
[data-mbp-listing] .dl-card,
[data-mbp-listing] .plc {
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
}

/* ════════════════════════════════════════════════════════════════════════
   SPECIALIST LISTING  [mbp_specialist_listing]
════════════════════════════════════════════════════════════════════════ */

/* hero */
[data-mbp-listing] .sl-hero {
    background: linear-gradient(135deg, var(--sl-nav,#1B3A5C), var(--sl-acc,#0B7A75)) !important;
    border-radius: 14px; padding: 18px 22px; color: #fff;
    margin-bottom: 24px; position: relative; overflow: hidden;
}
[data-mbp-listing] .sl-hero::before {
    content: ''; position: absolute; right: -30px; top: -30px;
    width: 120px; height: 120px; border-radius: 50%;
    background: rgba(255,255,255,.07); pointer-events: none;
}
[data-mbp-listing] .sl-hero-row  { display: flex !important; align-items: center; gap: 12px; }
[data-mbp-listing] .sl-hero-ico  { font-size: clamp(1.6rem,3vw,2.2rem); flex-shrink: 0; line-height: 1; }
[data-mbp-listing] .sl-hero-txt h1 { font-size: clamp(.95rem,2.2vw,1.35rem); font-weight: 800; margin: 0 0 3px; line-height: 1.2; }
[data-mbp-listing] .sl-hero-txt p  { font-size: .82rem; opacity: .82; margin: 0; }
[data-mbp-listing] .sl-chips-row  { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
[data-mbp-listing] .sl-chip { background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3); color: #fff; font-size: .68rem; font-weight: 600; padding: 3px 10px; border-radius: 20px; white-space: nowrap; }

/* filter bar */
[data-mbp-listing] .sl-fbar { display: flex !important; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 22px; padding: 12px 14px; background: #f8fafc; border-radius: 12px; border: 1px solid rgba(0,0,0,.08); }
[data-mbp-listing] .sl-search { flex: 1; min-width: 160px; border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 12px; font-size: .85rem; font-family: inherit; background: #fff; color: #1e293b; outline: none; }
[data-mbp-listing] .sl-search:focus { border-color: var(--sl-acc,#0B7A75); }
[data-mbp-listing] .sl-fsel { border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 10px; font-size: .82rem; font-family: inherit; background: #fff; color: #1e293b; cursor: pointer; outline: none; }
[data-mbp-listing] .sl-fcount { font-size: .76rem; color: #64748b; white-space: nowrap; margin-left: auto; }

/* dept heading (3-D tablet effect) */
[data-mbp-listing] .sl-sec { margin-bottom: 32px; }
[data-mbp-listing] .sl-dh {
    display: inline-flex !important; align-items: center; gap: 9px;
    margin-bottom: 14px; padding: 9px 18px 9px 12px; border-radius: 10px;
    background: linear-gradient(135deg, var(--sl-nav,#1B3A5C), var(--sl-acc,#0B7A75)) !important;
    color: #fff !important; font-size: .82rem; font-weight: 800;
    letter-spacing: .05em; text-transform: uppercase;
    box-shadow: 0 4px 0 rgba(0,0,0,.25), 0 7px 14px rgba(15,30,92,.2);
    transform: perspective(200px) rotateX(3deg); transform-origin: top left;
    cursor: default; user-select: none; position: relative;
}
[data-mbp-listing] .sl-dh::before { content: ''; position: absolute; inset: 0; border-radius: 10px; background: linear-gradient(180deg,rgba(255,255,255,.14) 0%,transparent 55%); pointer-events: none; }
[data-mbp-listing] .sl-dh-cnt { background: rgba(255,255,255,.22); font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 20px; margin-left: 4px; }

/* GRID */
[data-mbp-listing] .sl-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--sl-card-w,240px), 100%), 1fr)) !important;
    gap: var(--sl-card-gap,16px) !important;
}

/* card */
[data-mbp-listing] .sl-card {
    display: flex !important; flex-direction: column !important;
    border-radius: var(--sl-card-r,14px) !important;
    overflow: hidden !important;
    background: var(--sl-card-bg,#fff) !important;
    box-shadow: var(--sl-card-shd,0 2px 16px rgba(15,30,60,.09)) !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    transition: transform .2s, box-shadow .2s !important;
    position: relative !important;
}
[data-mbp-listing] .sl-card:hover { transform: translateY(-4px) !important; box-shadow: 0 14px 40px rgba(0,0,0,.13) !important; }
[data-mbp-listing] .sl-ctop {
    background: linear-gradient(135deg, var(--sl-nav,#1B3A5C), var(--sl-nav2,var(--sl-nav,#1B3A5C))) !important;
    padding: 14px 14px 0 !important; display: flex !important; gap: 10px !important;
    align-items: flex-end !important; min-height: 88px !important;
}
[data-mbp-listing] .sl-photo { width: 64px !important; height: 64px !important; border-radius: 10px !important; object-fit: cover !important; flex-shrink: 0 !important; border: 2px solid rgba(255,255,255,.3) !important; background: rgba(255,255,255,.12) !important; }
[data-mbp-listing] .sl-photo-ph { width: 64px !important; height: 64px !important; border-radius: 10px !important; flex-shrink: 0 !important; background: rgba(255,255,255,.14) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 1.65rem !important; color: rgba(255,255,255,.8) !important; }
[data-mbp-listing] .sl-ctop-info { flex: 1 !important; padding-bottom: 12px !important; min-width: 0 !important; }
[data-mbp-listing] .sl-spec-pill { display: inline-block !important; background: rgba(255,255,255,.2) !important; color: #fff !important; font-size: .62rem !important; font-weight: 700 !important; padding: 2px 9px !important; border-radius: 20px !important; margin-bottom: 5px !important; max-width: 100% !important; overflow: hidden !important; text-overflow: ellipsis !important; white-space: nowrap !important; }
[data-mbp-listing] .sl-name { font-size: .9rem !important; font-weight: 800 !important; color: #fff !important; line-height: 1.25 !important; margin-bottom: 3px !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
[data-mbp-listing] .sl-qual { font-size: .66rem !important; color: rgba(255,255,255,.70) !important; line-height: 1.4 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
[data-mbp-listing] .sl-cbody { padding: 11px 13px 6px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; gap: 5px !important; }
[data-mbp-listing] .sl-tags  { display: flex !important; flex-wrap: wrap !important; gap: 4px !important; }
[data-mbp-listing] .sl-tag   { background: rgba(0,0,0,.05) !important; color: var(--sl-acc,#0B7A75) !important; font-size: .62rem !important; font-weight: 600 !important; padding: 2px 8px !important; border-radius: 20px !important; border: 1px solid rgba(0,0,0,.08) !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; max-width: 100% !important; }
[data-mbp-listing] .sl-infos { display: flex !important; flex-wrap: wrap !important; gap: 4px !important; margin-top: auto !important; padding-top: 6px !important; }
[data-mbp-listing] .sl-info  { display: flex !important; align-items: center !important; gap: 3px !important; font-size: .70rem !important; color: #64748b !important; background: #f8fafc !important; padding: 3px 7px !important; border-radius: 20px !important; white-space: nowrap !important; }
[data-mbp-listing] .sl-fee   { color: var(--sl-acc,#0B7A75) !important; font-weight: 700 !important; }
[data-mbp-listing] .sl-cfoot { padding: 9px 13px 13px !important; border-top: 1px solid #f1f5f9 !important; display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 7px !important; margin-top: auto !important; }
[data-mbp-listing] .sl-btn-book { display: flex !important; align-items: center !important; justify-content: center !important; padding: 10px 6px !important; border-radius: var(--sl-btn-r,9px) !important; background: var(--sl-btn-bg,var(--sl-acc,#0B7A75)) !important; color: var(--sl-btn-col,#fff) !important; font-size: .76rem !important; font-weight: 700 !important; text-decoration: none !important; border: none !important; cursor: pointer !important; font-family: inherit !important; min-height: 40px !important; line-height: 1.2 !important; text-align: center !important; transition: opacity .15s !important; }
[data-mbp-listing] .sl-btn-book:hover { opacity: .88 !important; }
[data-mbp-listing] .sl-btn-ask { display: flex !important; align-items: center !important; justify-content: center !important; padding: 10px 6px !important; border-radius: var(--sl-btn-r,9px) !important; background: rgba(109,40,217,.07) !important; color: #6d28d9 !important; border: 1.5px solid rgba(109,40,217,.18) !important; font-size: .76rem !important; font-weight: 700 !important; cursor: pointer !important; font-family: inherit !important; min-height: 40px !important; line-height: 1.2 !important; text-align: center !important; transition: all .15s !important; }
[data-mbp-listing] .sl-btn-ask:hover { background: #6d28d9 !important; color: #fff !important; border-color: #6d28d9 !important; }
[data-mbp-listing] .sl-btn-full { grid-column: 1 / -1 !important; }
[data-mbp-listing] .sl-empty { text-align: center; padding: 48px 20px; color: #94a3b8; font-size: .88rem; display: none; }

/* chat overlay */
[data-mbp-listing] .sl-chatov { position: fixed !important; inset: 0 !important; z-index: 99990 !important; display: none !important; align-items: flex-end !important; justify-content: flex-end !important; padding: 16px !important; pointer-events: none !important; background: rgba(0,0,0,.4) !important; }
[data-mbp-listing] .sl-chatov.open { display: flex !important; pointer-events: all !important; }
[data-mbp-listing] .sl-chatbox { background: #fff !important; border-radius: 18px !important; width: min(420px,95vw) !important; height: min(600px,85vh) !important; box-shadow: 0 20px 60px rgba(0,0,0,.3) !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; }
[data-mbp-listing] .sl-chathd { background: linear-gradient(135deg,var(--sl-nav,#1B3A5C),var(--sl-acc,#0B7A75)) !important; padding: 13px 15px !important; display: flex !important; align-items: center !important; gap: 10px !important; flex-shrink: 0 !important; }
[data-mbp-listing] .sl-chathd h3 { color: #fff !important; font-size: 13px !important; font-weight: 800 !important; flex: 1 !important; margin: 0 !important; }
[data-mbp-listing] .sl-chathd p  { color: rgba(255,255,255,.65) !important; font-size: 10px !important; margin: 0 !important; }
[data-mbp-listing] .sl-chatcl { background: rgba(255,255,255,.15) !important; border: none !important; color: #fff !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; cursor: pointer !important; font-size: 14px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
[data-mbp-listing] .sl-chatifr { flex: 1 !important; border: none !important; width: 100% !important; }

/* ════════════════════════════════════════════════════════════════════════
   DIAGNOSTIC LISTING  [mbp_lab_tests] / [mbp_scans]
════════════════════════════════════════════════════════════════════════ */

/* hero */
[data-mbp-listing] .dl-hero { background: linear-gradient(135deg,var(--dl-nav,#1B3A5C),var(--dl-acc,#0B7A75)) !important; border-radius: 14px; padding: 22px 24px; margin-bottom: 20px; color: #fff; }
[data-mbp-listing] .dl-hero h1 { margin: 0 0 6px; font-size: clamp(1.05rem,2.5vw,1.45rem); font-weight: 800; }
[data-mbp-listing] .dl-hero p  { margin: 0 0 14px; font-size: .82rem; opacity: .82; }
[data-mbp-listing] .dl-stats { display: flex !important; gap: 10px; flex-wrap: wrap; }
[data-mbp-listing] .dl-stat  { background: rgba(255,255,255,.15); border-radius: 10px; padding: 8px 14px; text-align: center; }
[data-mbp-listing] .dl-stat b    { display: block; font-size: 1.1rem; font-weight: 800; }
[data-mbp-listing] .dl-stat span { display: block; font-size: .62rem; opacity: .75; margin-top: 1px; }

/* filter */
[data-mbp-listing] .dl-filter { display: flex !important; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 20px; }
[data-mbp-listing] .dl-search { flex: 1; min-width: 160px; border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 12px; font-size: .85rem; font-family: inherit; background: #fff; color: #1e293b; outline: none; }
[data-mbp-listing] .dl-search:focus { border-color: var(--dl-acc,#0B7A75); }
[data-mbp-listing] .dl-pills { display: flex; flex-wrap: wrap; gap: 6px; }
[data-mbp-listing] .dl-pill { background: #f1f5f9; border: 1.5px solid transparent; border-radius: 20px; padding: 5px 14px; font-size: .75rem; font-weight: 600; cursor: pointer; font-family: inherit; color: #475569; transition: all .15s; white-space: nowrap; }
[data-mbp-listing] .dl-pill:hover, [data-mbp-listing] .dl-pill.active { background: var(--dl-acc,#0B7A75) !important; color: #fff !important; border-color: var(--dl-acc,#0B7A75) !important; }
[data-mbp-listing] .dl-catsel { display: none; border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 10px; font-size: .82rem; font-family: inherit; background: #fff; color: #1e293b; cursor: pointer; }

/* section heading */
[data-mbp-listing] .dl-section { margin-bottom: 28px; }
[data-mbp-listing] .dl-sec-head { display: inline-flex !important; align-items: center; gap: 8px; margin-bottom: 12px; padding: 8px 16px; border-radius: 9px; background: linear-gradient(135deg,var(--dl-nav,#1B3A5C),var(--dl-acc,#0B7A75)) !important; color: #fff !important; font-size: .76rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; }
[data-mbp-listing] .dl-sec-count { background: rgba(255,255,255,.22); font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 20px; }

/* GRID */
[data-mbp-listing] .dl-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--dl-card-w,160px), 100%), 1fr)) !important;
    gap: var(--dl-card-gap,12px) !important;
}

/* card */
[data-mbp-listing] .dl-card {
    background: var(--dl-card-bg,#fff) !important;
    border-radius: var(--dl-card-r,12px) !important;
    border: 1.5px solid #e8ecf0 !important;
    border-left: 4px solid var(--dl-acc,#0B7A75) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.07) !important;
    display: flex !important; flex-direction: column !important;
    overflow: hidden !important; cursor: pointer !important;
    transition: transform .18s, box-shadow .18s, border-left-color .18s !important;
}
[data-mbp-listing] .dl-card:hover { transform: translateY(-3px) !important; box-shadow: 0 8px 28px rgba(0,0,0,.14) !important; border-left-color: var(--dl-nav,#1B3A5C) !important; }
[data-mbp-listing] .dl-card.cart-added-state { border-left-color: #059669 !important; border-color: rgba(5,150,105,.4) !important; background: rgba(5,150,105,.03) !important; }

[data-mbp-listing] .dl-card-top { display: flex !important; align-items: flex-start !important; gap: 10px !important; padding: 12px 13px 8px !important; }
[data-mbp-listing] .dl-icon { width: 34px !important; height: 34px !important; border-radius: 8px !important; flex-shrink: 0 !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 1.15rem !important; border: 2px solid var(--dl-acc,#0B7A75) !important; background: var(--dl-tint,rgba(11,122,117,.08)) !important; align-self: flex-start !important; }
[data-mbp-listing] .dl-name { font-size: .82rem !important; font-weight: 700 !important; color: #1e293b !important; line-height: 1.38 !important; flex: 1 !important; padding-top: 2px !important; display: -webkit-box !important; -webkit-line-clamp: 3 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; word-break: break-word !important; }

[data-mbp-listing] .dl-card-bot { padding: 0 13px 12px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; gap: 6px !important; }
[data-mbp-listing] .dl-offer-tag { display: inline-block !important; font-size: .62rem !important; font-weight: 700 !important; padding: 2px 8px !important; border-radius: 20px !important; color: var(--dl-offer-col,#b8852e) !important; border: 1px solid rgba(184,133,46,.3) !important; background: var(--dl-offer-bg,rgba(201,150,62,.12)) !important; }
[data-mbp-listing] .dl-price-wrap { flex: 1 !important; display: flex !important; flex-direction: column !important; justify-content: flex-end !important; gap: 6px !important; }
[data-mbp-listing] .dl-price { font-size: 1.05rem !important; font-weight: 800 !important; color: var(--dl-price-col,var(--dl-acc,#0B7A75)) !important; line-height: 1 !important; }
[data-mbp-listing] .dl-btn {
    display: block !important; width: 100% !important;
    background: var(--dl-btn-bg,var(--dl-acc,#0B7A75)) !important;
    color: var(--dl-btn-col,#fff) !important;
    border: none !important; border-radius: var(--dl-btn-r,8px) !important;
    padding: 9px 10px !important; font-size: 12.5px !important; font-weight: 700 !important;
    cursor: pointer !important; font-family: inherit !important; text-align: center !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.16) !important; flex-shrink: 0 !important;
    transition: opacity .15s !important;
}
[data-mbp-listing] .dl-btn:hover { opacity: .85 !important; }
[data-mbp-listing] .dl-btn.bfh-in-cart { background: rgba(5,150,105,.1) !important; color: #065f46 !important; border: 1.5px solid rgba(5,150,105,.3) !important; box-shadow: none !important; }

/* packages grid */
[data-mbp-listing] .dl-pkg-grid { display: grid !important; grid-template-columns: repeat(auto-fill,minmax(min(240px,100%),1fr)) !important; gap: 14px !important; margin-top: 14px !important; }
[data-mbp-listing] .dl-pkg { background: #fff !important; border-radius: 12px !important; border: 1.5px solid #e8ecf0 !important; overflow: hidden !important; display: flex !important; flex-direction: column !important; }
[data-mbp-listing] .dl-pkg-head { background: linear-gradient(135deg,var(--dl-nav,#1B3A5C),var(--dl-acc,#0B7A75)) !important; padding: 14px 16px !important; }
[data-mbp-listing] .dl-pkg-name { color: #fff !important; font-size: .88rem !important; font-weight: 800 !important; margin-bottom: 4px !important; }
[data-mbp-listing] .dl-pkg-sub  { color: rgba(255,255,255,.75) !important; font-size: .72rem !important; }
[data-mbp-listing] .dl-pkg-body { padding: 14px 16px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; gap: 8px !important; }
[data-mbp-listing] .dl-pkg-price { font-size: 1.1rem !important; font-weight: 800 !important; color: var(--dl-acc,#0B7A75) !important; }
[data-mbp-listing] .dl-pkg-desc  { font-size: .78rem !important; color: #64748b !important; line-height: 1.5 !important; }
[data-mbp-listing] .dl-pkg-btn { display: block !important; width: 100% !important; background: var(--dl-btn-bg,var(--dl-acc,#0B7A75)) !important; color: var(--dl-btn-col,#fff) !important; border: none !important; border-radius: 8px !important; padding: 10px !important; font-size: 13px !important; font-weight: 700 !important; cursor: pointer !important; font-family: inherit !important; text-align: center !important; margin-top: auto !important; transition: opacity .15s !important; }
[data-mbp-listing] .dl-pkg-btn:hover { opacity: .85 !important; }

/* chat overlay */
[data-mbp-listing~="0"] { display: none; } /* unused placeholder */
[id$="-chat-ov"] { position: fixed !important; inset: 0 !important; z-index: 99991 !important; display: none !important; align-items: flex-end !important; justify-content: flex-end !important; padding: 16px !important; background: rgba(0,0,0,.4) !important; }
[id$="-chat-ov"].open { display: flex !important; }
[id$="-chat-box"] { background: #fff !important; border-radius: 18px !important; width: min(420px,95vw) !important; height: min(600px,85vh) !important; box-shadow: 0 20px 60px rgba(0,0,0,.3) !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; }
[id$="-chat-head"] { background: linear-gradient(135deg,#1B3A5C,#0B7A75) !important; padding: 13px 15px !important; display: flex !important; align-items: center !important; gap: 10px !important; flex-shrink: 0 !important; }
[id$="-chat-head"] h3 { color: #fff !important; font-size: 13px !important; font-weight: 800 !important; flex: 1 !important; margin: 0 !important; }
[id$="-chat-head"] p  { color: rgba(255,255,255,.65) !important; font-size: 10px !important; margin: 0 !important; }
[id$="-chat-close"] { background: rgba(255,255,255,.15) !important; border: none !important; color: #fff !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; cursor: pointer !important; font-size: 14px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
[id$="-chat-frame"] { flex: 1 !important; border: none !important; width: 100% !important; }

/* ════════════════════════════════════════════════════════════════════════
   PROCEDURES LISTING  [mbp_procedures]
════════════════════════════════════════════════════════════════════════ */

/* hero */
[data-mbp-listing] .plh { background: linear-gradient(135deg,var(--pl-nav,#1B3A5C),var(--pl-acc,#0B7A75)) !important; border-radius: 14px; padding: 20px 22px; margin-bottom: 22px; color: #fff; }
[data-mbp-listing] .plh-row { display: flex !important; align-items: center; gap: 14px; }
[data-mbp-listing] .plh-ico { font-size: 2rem; flex-shrink: 0; background: rgba(255,255,255,.15); width: 52px; height: 52px; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
[data-mbp-listing] .plh h1 { margin: 0 0 4px; font-size: clamp(1rem,2.5vw,1.4rem); font-weight: 800; }
[data-mbp-listing] .plh p  { margin: 0 0 14px; font-size: .82rem; opacity: .82; }
[data-mbp-listing] .plh-stats { display: flex !important; gap: 10px; flex-wrap: wrap; }
[data-mbp-listing] .plh-stat { background: rgba(255,255,255,.15); border-radius: 10px; padding: 8px 14px; text-align: center; }
[data-mbp-listing] .plh-stat b    { display: block; font-size: 1.1rem; font-weight: 800; }
[data-mbp-listing] .plh-stat span { display: block; font-size: .62rem; opacity: .75; }

/* filter bar */
[data-mbp-listing] .plf { display: flex !important; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 22px; padding: 12px 14px; background: #f8fafc; border-radius: 12px; border: 1px solid rgba(0,0,0,.08); }
[data-mbp-listing] .plf-srch { flex: 1; min-width: 160px; border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 12px; font-size: .85rem; font-family: inherit; background: #fff; color: #1e293b; outline: none; }
[data-mbp-listing] .plf-dept { border: 1.5px solid rgba(0,0,0,.12); border-radius: 9px; padding: 8px 10px; font-size: .82rem; font-family: inherit; background: #fff; color: #1e293b; cursor: pointer; }
[data-mbp-listing] .plf-count { font-size: .76rem; color: #64748b; white-space: nowrap; margin-left: auto; }

/* dept group */
[data-mbp-listing] .pld { margin-bottom: 32px; }
[data-mbp-listing] .pld-head { display: inline-flex !important; align-items: center; gap: 8px; margin-bottom: 14px; padding: 8px 16px; border-radius: 9px; background: linear-gradient(135deg,var(--pl-nav,#1B3A5C),var(--pl-acc,#0B7A75)) !important; color: #fff !important; font-size: .78rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
[data-mbp-listing] .pld-cnt { background: rgba(255,255,255,.22); font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 20px; }

/* GRID */
[data-mbp-listing] .plg {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--pl-card-w,220px), 100%), 1fr)) !important;
    gap: var(--pl-card-gap,14px) !important;
}

/* card */
[data-mbp-listing] .plc {
    background: var(--pl-card-bg,#fff) !important;
    border-radius: var(--pl-card-r,14px) !important;
    box-shadow: var(--pl-card-shd,0 2px 14px rgba(0,0,0,.08)) !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    display: flex !important; flex-direction: column !important;
    overflow: hidden !important; position: relative !important;
    transition: transform .2s, box-shadow .2s !important;
}
[data-mbp-listing] .plc:hover { transform: translateY(-3px) !important; box-shadow: 0 10px 32px rgba(0,0,0,.13) !important; }
[data-mbp-listing] .plc-media { padding: 14px 14px 8px !important; position: relative !important; overflow: hidden !important; }
[data-mbp-listing] .plc-img   { width: 100% !important; height: auto !important; aspect-ratio: 16/9 !important; object-fit: cover !important; border-radius: 9px !important; display: block !important; margin-bottom: 8px !important; }
[data-mbp-listing] .plc-emoji { width: 100% !important; aspect-ratio: 16/9 !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 2.2rem !important; border-radius: 9px !important; margin-bottom: 8px !important; background: var(--pl-tint,rgba(11,122,117,.08)) !important; }
[data-mbp-listing] .plc-badge { position: absolute !important; top: 14px !important; left: 14px !important; background: var(--pl-acc,#0B7A75) !important; color: #fff !important; font-size: .65rem !important; font-weight: 700 !important; padding: 2px 9px !important; border-radius: 20px !important; z-index: 2 !important; }
[data-mbp-listing] .plc-name  { font-size: .9rem !important; font-weight: 800 !important; color: #1e293b !important; line-height: 1.25 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
[data-mbp-listing] .plc-dept  { font-size: .68rem !important; color: var(--pl-acc,#0B7A75) !important; font-weight: 600 !important; margin-top: 4px !important; }
[data-mbp-listing] .plc-info  { padding: 8px 14px 6px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; gap: 6px !important; }
[data-mbp-listing] .plc-tag   { display: inline-block !important; background: rgba(0,0,0,.05) !important; color: var(--pl-acc,#0B7A75) !important; font-size: .63rem !important; font-weight: 600 !important; padding: 2px 8px !important; border-radius: 20px !important; border: 1px solid rgba(0,0,0,.08) !important; }
[data-mbp-listing] .plc-price-row { display: flex !important; align-items: center !important; gap: 6px !important; flex-wrap: wrap !important; }
[data-mbp-listing] .plc-price { font-size: .95rem !important; font-weight: 800 !important; color: var(--pl-acc,#0B7A75) !important; }
[data-mbp-listing] .plc-disc  { background: #fef3c7 !important; color: #92400e !important; font-size: .62rem !important; font-weight: 700 !important; padding: 2px 7px !important; border-radius: 20px !important; }
[data-mbp-listing] .plc-orig  { font-size: .72rem !important; color: #94a3b8 !important; text-decoration: line-through !important; }
[data-mbp-listing] .plc-desc  { font-size: .78rem !important; color: #64748b !important; line-height: 1.5 !important; display: -webkit-box !important; -webkit-line-clamp: 3 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
[data-mbp-listing] .plc-meta  { display: flex !important; flex-wrap: wrap !important; gap: 5px !important; margin-top: auto !important; padding-top: 4px !important; }
[data-mbp-listing] .plc-meta-pill { display: flex !important; align-items: center !important; gap: 3px !important; font-size: .68rem !important; color: #64748b !important; background: #f8fafc !important; padding: 3px 7px !important; border-radius: 20px !important; }
[data-mbp-listing] .plc-foot  { padding: 10px 14px 14px !important; border-top: 1px solid #f1f5f9 !important; display: flex !important; flex-direction: column !important; gap: 6px !important; margin-top: auto !important; }
[data-mbp-listing] .plc-book,
[data-mbp-listing] .plc-ask {
    display: flex !important; align-items: center !important; justify-content: center !important;
    width: 100% !important; min-height: 42px !important;
    border-radius: var(--pl-btn-r,9px) !important;
    font-size: var(--pl-btn-sz,13px) !important; font-weight: 700 !important;
    cursor: pointer !important; font-family: inherit !important;
    text-align: center !important; text-decoration: none !important;
    transition: opacity .15s, transform .1s !important;
}
[data-mbp-listing] .plc-book { gap: 5px !important; padding: 10px 12px !important; background: var(--pl-btn-bg,var(--pl-acc,#0B7A75)) !important; color: var(--pl-btn-col,#fff) !important; border: none !important; box-shadow: 0 3px 10px rgba(0,0,0,.18) !important; }
[data-mbp-listing] .plc-book:hover { opacity: .88 !important; }
[data-mbp-listing] .plc-ask  { padding: 8px !important; background: rgba(109,40,217,.08) !important; color: #6d28d9 !important; border: 1.5px solid rgba(109,40,217,.2) !important; }
[data-mbp-listing] .plc-ask:hover { background: #6d28d9 !important; color: #fff !important; border-color: #6d28d9 !important; }

/* chat overlay (procedures) */
[id$="-cov"] { position: fixed !important; inset: 0 !important; z-index: 99991 !important; display: none !important; align-items: flex-end !important; justify-content: flex-end !important; padding: 16px !important; background: rgba(0,0,0,.4) !important; }
[id$="-cov"].open { display: flex !important; }
[id$="-cbox"] { background: #fff !important; border-radius: 18px !important; width: min(420px,95vw) !important; height: min(600px,85vh) !important; box-shadow: 0 20px 60px rgba(0,0,0,.3) !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; }
[id$="-chd"] { background: linear-gradient(135deg,#1B3A5C,#0B7A75) !important; padding: 13px 15px !important; display: flex !important; align-items: center !important; gap: 10px !important; flex-shrink: 0 !important; }
[id$="-chd"] h3 { color: #fff !important; font-size: 13px !important; font-weight: 800 !important; flex: 1 !important; margin: 0 !important; }
[id$="-chd"] p  { color: rgba(255,255,255,.65) !important; font-size: 10px !important; margin: 0 !important; }
[id$="-ccl"] { background: rgba(255,255,255,.15) !important; border: none !important; color: #fff !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; cursor: pointer !important; }
[id$="-cfr"] { flex: 1 !important; border: none !important; width: 100% !important; }

/* empty state */
[data-mbp-listing] .ple { display: none; text-align: center; padding: 48px 20px; color: #94a3b8; }

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════════════════ */
@media(max-width:900px){
    [data-mbp-listing] .sl-grid { grid-template-columns: repeat(auto-fill,minmax(min(200px,100%),1fr)) !important; gap: 12px !important; }
    [data-mbp-listing] .dl-grid { grid-template-columns: repeat(auto-fill,minmax(min(150px,100%),1fr)) !important; }
    [data-mbp-listing] .plg     { grid-template-columns: repeat(auto-fill,minmax(min(200px,100%),1fr)) !important; }
}
@media(max-width:660px){
    [data-mbp-listing] .sl-grid { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
    [data-mbp-listing] .sl-ctop { min-height: 72px !important; padding: 10px 10px 0 !important; }
    [data-mbp-listing] .sl-photo, [data-mbp-listing] .sl-photo-ph { width: 52px !important; height: 52px !important; }
    [data-mbp-listing] .sl-cfoot { grid-template-columns: 1fr !important; gap: 5px !important; }
    [data-mbp-listing] .sl-btn-book, [data-mbp-listing] .sl-btn-ask { grid-column: 1/-1 !important; min-height: 36px !important; }
    [data-mbp-listing] .sl-fbar { flex-direction: column !important; align-items: stretch !important; }
    [data-mbp-listing] .dl-pills { display: none !important; }
    [data-mbp-listing] .dl-catsel { display: block !important; }
    [data-mbp-listing] .dl-grid { grid-template-columns: repeat(auto-fill,minmax(min(145px,100%),1fr)) !important; gap: 10px !important; }
    [data-mbp-listing] .dl-name { -webkit-line-clamp: 2 !important; }
    [data-mbp-listing] .plg { grid-template-columns: repeat(auto-fill,minmax(min(160px,100%),1fr)) !important; gap: 10px !important; }
    [data-mbp-listing] .plf { flex-direction: column !important; align-items: stretch !important; }
    [data-mbp-listing] .plc-foot { gap: 5px !important; }
}
@media(max-width:400px){
    [data-mbp-listing] .sl-grid { grid-template-columns: 1fr !important; }
    [data-mbp-listing] .dl-grid { grid-template-columns: 1fr !important; gap: 8px !important; }
    [data-mbp-listing] .plg     { grid-template-columns: 1fr !important; }
    [data-mbp-listing] .dl-name { -webkit-line-clamp: 3 !important; }
}
