/* ================================================================
   BudLocations Map — BudDocs Color System v6.0
   Colors extracted from buddocs.org:
     Header bg:  #0d1f2d  (deep navy-teal)
     Accent:     #2dd4aa  (bright teal-green)
     CTA hover:  #1db896
     Surface:    #ffffff
     Text dark:  #0d1f2d
   ================================================================ */

:root {
  --f: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI",
       Roboto, "Helvetica Neue", Arial, sans-serif;

  /* ── BudDocs brand palette ───────────────────────────────── */
  --bd-navy:     #0d1f2d;   /* header / dark surfaces          */
  --bd-navy-2:   #162636;   /* slightly lighter dark            */
  --bd-navy-3:   #1e3347;   /* card hover dark state            */
  --bd-teal:     #2dd4aa;   /* primary CTA / accent             */
  --bd-teal-dk:  #1db896;   /* teal hover                       */
  --bd-teal-lt:  #e6faf6;   /* teal tint on white               */
  --bd-teal-dim: rgba(45,212,170,.14);

  /* ── Neutral surfaces ───────────────────────────────────── */
  --c-surface:   #ffffff;
  --c-surface-2: #f7f9fb;
  --c-surface-3: #eef2f6;

  /* ── Borders ────────────────────────────────────────────── */
  --c-border:    rgba(13,31,45,.08);
  --c-border-md: rgba(13,31,45,.14);

  /* ── Text ───────────────────────────────────────────────── */
  --c-ink:   #0d1f2d;
  --c-text:  #1a2e3d;
  --c-muted: #5a6e7d;
  --c-hint:  #94aab8;

  /* ── Status ─────────────────────────────────────────────── */
  --c-open:    #059669;
  --c-open-bg: #d1fae5;
  --c-cls:     #dc2626;
  --c-cls-bg:  #fee2e2;
  --c-star:    #d97706;

  /* ── Radii ──────────────────────────────────────────────── */
  --r-xs:  6px;
  --r-sm:  10px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  26px;
  --r-pill:999px;

  /* ── Elevation ──────────────────────────────────────────── */
  --e-1: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);
  --e-2: 0 4px 14px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.04);
  --e-3: 0 12px 36px rgba(0,0,0,.12), 0 4px 10px rgba(0,0,0,.06);
  --e-4: 0 24px 60px rgba(0,0,0,.2),  0 8px 20px rgba(0,0,0,.09);

  --ease: cubic-bezier(.4,0,.2,1);
  --t: .17s;
}

/* ── Reset ───────────────────────────────────────────────────── */
.budmap-wrap *, .budmap-wrap *::before, .budmap-wrap *::after {
  box-sizing: border-box;
}

.budmap-wrap {
  font-family: var(--f);
  font-size: 15px;
  color: var(--c-text);
  background: var(--c-surface);
  max-width: 1320px;
  margin: 0 auto;
  overflow: hidden;
}

/* ================================================================
   HERO HEADER — BudDocs navy
   ================================================================ */

.budmap-hero {
  background: var(--bd-navy);
  padding: 14px 16px 18px;
  position: relative;
}

/* Subtle teal glow top-right matching BudDocs header */
.budmap-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 95% 0%,
    rgba(45,212,170,.12) 0%, transparent 65%);
  pointer-events: none;
}

/* ── Search bar ──────────────────────────────────────────────── */
.budmap-search-row {
  display: flex;
  gap: 8px;
  align-items: center;
  position: relative;
  z-index: 1;
  margin-bottom: 10px;
}

.budmap-search-wrap {
  flex: 1;
  position: relative;
}

.budmap-search-wrap::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='rgba(255,255,255,.45)' stroke-width='1.8' stroke-linecap='round'%3E%3Ccircle cx='8.5' cy='8.5' r='5.5'/%3E%3Cpath d='M13 13l3.5 3.5'/%3E%3C/svg%3E") center/contain no-repeat;
  pointer-events: none;
}

#budmap-search {
  width: 100%;
  padding: 12px 14px 12px 40px;
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  font-size: 15px;
  font-family: var(--f);
  color: #fff;
  outline: none;
  -webkit-appearance: none;
  transition: background var(--t), border-color var(--t), box-shadow var(--t);
}
#budmap-search::placeholder { color: rgba(255,255,255,.4); }
#budmap-search:focus {
  background: rgba(255,255,255,.12);
  border-color: var(--bd-teal);
  box-shadow: 0 0 0 3px rgba(45,212,170,.2);
}

/* ── Near Me button ──────────────────────────────────────────── */
#budmap-locate {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 18px;
  background: var(--bd-teal);
  border: none;
  border-radius: var(--r-pill);
  color: var(--bd-navy);
  font-size: 14px;
  font-family: var(--f);
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: -.01em;
  transition: background var(--t), color var(--t), transform .1s;
  -webkit-tap-highlight-color: transparent;
}
#budmap-locate:hover  { background: var(--bd-teal-dk); color: #fff; }
#budmap-locate:active { transform: scale(.96); }

/* ── Filter chips ────────────────────────────────────────────── */
.budmap-filter-chips {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 2px;
  position: relative;
  z-index: 1;
}
.budmap-filter-chips::-webkit-scrollbar { display: none; }

.budmap-chip { flex-shrink: 0; }
.budmap-chip-label {
  display: none;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: rgba(255,255,255,.45);
  margin-bottom: 3px;
}

.budmap-chip select {
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,.09)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(255,255,255,.55)' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    right 10px center no-repeat;
  border: 1.5px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  padding: 8px 28px 8px 13px;
  font-size: 13px;
  font-family: var(--f);
  color: rgba(255,255,255,.82);
  cursor: pointer;
  white-space: nowrap;
  outline: none;
  transition: background var(--t), border-color var(--t);
}
.budmap-chip select:focus,
.budmap-chip select.active {
  border-color: var(--bd-teal);
  background-color: rgba(45,212,170,.18);
  color: #fff;
}

/* Radius chip */
.budmap-radius-chip {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  background: rgba(255,255,255,.09);
  border: 1.5px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  font-size: 13px;
  color: rgba(255,255,255,.82);
  white-space: nowrap;
}
.budmap-radius-chip input[type=range] {
  width: 72px;
  accent-color: var(--bd-teal);
  cursor: pointer;
  height: 3px;
}

/* Clear button */
#budmap-clear-filters {
  flex-shrink: 0;
  padding: 8px 14px;
  background: rgba(255,255,255,.07);
  border: 1.5px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-family: var(--f);
  color: rgba(255,255,255,.65);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--t), color var(--t);
}
#budmap-clear-filters:hover { background: rgba(255,255,255,.16); color: #fff; }

/* ================================================================
   STATUS BARS
   ================================================================ */

.budmap-status-bar {
  display: none;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 500;
  border-bottom: 1px solid var(--c-border);
}
.budmap-status-bar.visible { display: flex; }

.budmap-fav-bar  { background: #fffbeb; color: #92400e; }
.budmap-fav-label { font-weight: 700; }
.budmap-fav-count { margin-left: auto; opacity: .65; font-size: 12px; }

/* ================================================================
   NOTICE
   ================================================================ */

.budmap-notice {
  display: none;
  margin: 10px 14px 0;
  padding: 10px 14px;
  border-radius: var(--r-sm);
  background: #fff9ed;
  border-left: 3px solid var(--bd-teal);
  color: var(--c-text);
  font-size: 13px;
}

/* ================================================================
   MAP
   ================================================================ */

.budmap-map {
  width: 100%;
  height: 56vw;
  min-height: 240px;
  max-height: 520px;
  background: var(--c-surface-3);
}

.budmap-vendor-map {
  height: 260px;
  min-height: 180px;
  max-height: 340px;
  border-radius: var(--r-md);
  overflow: hidden;
  margin: 10px 0;
}

.budmap-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--c-surface-3);
  color: var(--c-muted);
  font-size: 14px;
  gap: 14px;
  width: 100%;
  /* Height is set inline to match the map height */
}
.budmap-loading .spinner {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 3px solid var(--c-surface-3);
  border-top-color: var(--bd-teal);
  animation: bm-spin .75s linear infinite;
}
@keyframes bm-spin { to { transform: rotate(360deg); } }

/* ================================================================
   LIST SECTION
   ================================================================ */

.budmap-list-section {
  padding: 14px 14px 6px;
}

.budmap-list-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.budmap-result-count {
  font-size: 13px;
  font-weight: 700;
  color: var(--c-text);
  margin-right: auto;
  letter-spacing: -.01em;
}

.budmap-list-toolbar label {
  font-size: 12px;
  color: var(--c-muted);
  font-weight: 600;
  white-space: nowrap;
}

.budmap-list-toolbar select {
  -webkit-appearance: none;
  appearance: none;
  background: var(--c-surface-2)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235a6e7d' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    right 10px center no-repeat;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  padding: 7px 28px 7px 12px;
  font-size: 13px;
  font-family: var(--f);
  color: var(--c-text);
  cursor: pointer;
  outline: none;
  min-width: 130px;
  transition: border-color var(--t);
}
.budmap-list-toolbar select:focus { border-color: var(--bd-teal); }

/* ================================================================
   CARDS
   ================================================================ */

.budmap-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  padding-bottom: 20px;
}

.budmap-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--e-1);
  transition: box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
}
.budmap-card:hover {
  box-shadow: var(--e-2);
  border-color: rgba(45,212,170,.3);
}

/* Card body */
.budmap-card-body {
  padding: 14px 14px 10px;
}

.budmap-card .hdr {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.budmap-card .logo { flex-shrink: 0; }
.budmap-card .logo img {
  width: 50px;
  height: 50px;
  object-fit: contain;
  border-radius: var(--r-sm);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  padding: 5px;
  display: block;
}

.budmap-card-title-row {
  display: flex;
  align-items: flex-start;
  gap: 4px;
}

.budmap-card-title-row .name {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--c-ink);
  line-height: 1.25;
  letter-spacing: -.015em;
}
.budmap-card-title-row .name a {
  color: inherit;
  text-decoration: none;
}
.budmap-card-title-row .name a:hover { color: var(--bd-teal-dk); }

.budmap-card .meta {
  font-size: 12px;
  color: var(--c-muted);
  margin-top: 3px;
  line-height: 1.4;
}

/* Info strip */
.budmap-card-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 7px;
}

.budmap-card .rating {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 12px;
  font-weight: 700;
  color: var(--c-star);
}

.budmap-dist {
  font-size: 12px;
  color: var(--c-hint);
  font-weight: 500;
}

/* Hours badge */
.budmap-hours-badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  background: var(--c-surface-3);
  color: var(--c-muted);
  letter-spacing: .01em;
}
.budmap-hours-badge.open   { background: var(--c-open-bg);  color: var(--c-open); }
.budmap-hours-badge.closed { background: var(--c-cls-bg);   color: var(--c-cls);  }

/* Promo banner */
.budmap-promo-badge { margin: 8px 0 0; }
.budmap-promo-badge a {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  background: linear-gradient(90deg, #f0fdf9 0%, #f7fffe 100%);
  border: 1px solid rgba(45,212,170,.3);
  border-radius: var(--r-xs);
  font-size: 12px;
  font-weight: 700;
  color: #065f46;
  text-decoration: none;
  transition: background var(--t);
}
.budmap-promo-badge a:hover { background: var(--bd-teal-lt); }

/* Hours expand */
.budmap-hours-toggle {
  font-size: 12px;
  color: var(--bd-teal-dk);
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px 0 0;
  font-family: var(--f);
  display: block;
  text-align: left;
}
.budmap-hours-full-wrap { margin-top: 6px; }
.budmap-hours-full { display: flex; flex-direction: column; gap: 2px; }
.budmap-hours-row  { font-size: 12px; color: var(--c-muted); padding: 1px 0; }
.budmap-hours-row.today  { font-weight: 700; color: var(--c-text); }
.budmap-hours-row.open   { color: var(--c-open); }
.budmap-hours-row.closed { color: var(--c-cls);  }

/* Favorite star */
.budmap-fav-btn {
  flex-shrink: 0;
  background: none;
  border: none;
  padding: 2px 4px;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  color: #d4dae0;
  transition: color var(--t), transform .12s;
  -webkit-tap-highlight-color: transparent;
}
.budmap-fav-btn:hover  { color: var(--c-star); transform: scale(1.25); }
.budmap-fav-btn.active { color: var(--c-star); }

/* ── Action bar ──────────────────────────────────────────────── */
.budmap-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  padding: 9px 14px 11px;
  border-top: 1px solid var(--c-border);
  background: var(--c-surface-2);
}

.budmap-link,
button.budmap-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-family: var(--f);
  font-weight: 600;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--c-border-md);
  color: var(--c-text);
  background: var(--c-surface);
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: -.005em;
  transition: background var(--t), border-color var(--t), color var(--t);
  -webkit-tap-highlight-color: transparent;
}
.budmap-link:hover,
button.budmap-link:hover {
  background: var(--bd-navy);
  border-color: var(--bd-navy);
  color: #fff;
}
.budmap-link:active,
button.budmap-link:active { transform: scale(.97); }

/* ================================================================
   GLOBAL BUTTONS
   ================================================================ */

.budmap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 20px;
  border: none;
  border-radius: var(--r-pill);
  background: var(--bd-teal);
  color: var(--bd-navy);
  font-size: 14px;
  font-family: var(--f);
  font-weight: 700;
  cursor: pointer;
  letter-spacing: -.01em;
  transition: background var(--t), color var(--t), transform .1s;
  -webkit-tap-highlight-color: transparent;
}
.budmap-btn:hover  { background: var(--bd-teal-dk); color: #fff; }
.budmap-btn:active { transform: scale(.97); }
.budmap-btn:disabled { opacity: .45; cursor: not-allowed; }

.budmap-btn.outline {
  background: transparent;
  border: 1.5px solid var(--c-border-md);
  color: var(--c-text);
}
.budmap-btn.outline:hover { background: var(--bd-navy); border-color: var(--bd-navy); color: #fff; }

.budmap-btn-sm { padding: 7px 13px; font-size: 12px; }

/* ================================================================
   FEATURED DISPENSARIES
   ================================================================ */

.budmap-featured-section { margin-bottom: 16px; }

.budmap-featured-heading {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.budmap-featured-heading span {
  font-size: 12px;
  font-weight: 800;
  color: var(--bd-teal-dk);
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
}
.budmap-featured-heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(45,212,170,.3) 0%, transparent 100%);
}

.budmap-featured-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

/* Featured card */
.budmap-card--featured {
  border-color: rgba(45,212,170,.3);
  box-shadow: inset 3px 0 0 var(--bd-teal), var(--e-2);
  background: linear-gradient(135deg, #f5fffe 0%, #fff 60%);
}
.budmap-card--featured:hover {
  border-color: rgba(45,212,170,.55);
  box-shadow: inset 3px 0 0 var(--bd-teal), 0 6px 20px rgba(45,212,170,.12);
}

/* Featured badge */
.budmap-featured-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: var(--bd-teal-lt);
  color: var(--bd-teal-dk);
  border: 1px solid rgba(45,212,170,.3);
  margin-left: 6px;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ================================================================
   LEAFLET OVERRIDES
   ================================================================ */

.leaflet-popup-content-wrapper {
  border-radius: var(--r-md) !important;
  box-shadow: var(--e-3) !important;
  border: 1px solid var(--c-border) !important;
}
.leaflet-popup-content { margin: 12px 14px !important; }
.leaflet-popup-tip { background: #fff !important; }

.budmap-popup { font-size: 13px; font-family: var(--f); line-height: 1.5; min-width: 160px; }
.budmap-popup strong { font-weight: 700; display: block; font-size: 14px; margin-bottom: 2px; color: var(--c-ink); }
.budmap-rating { font-size: 12px; font-weight: 700; color: var(--c-star); }
.budmap-popup-hours {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  margin-top: 3px;
}
.budmap-popup-hours.open   { background: var(--c-open-bg); color: var(--c-open); }
.budmap-popup-hours.closed { background: var(--c-cls-bg);  color: var(--c-cls);  }
.budmap-popup-promo { font-size: 11px; color: #065f46; font-weight: 600; }
.budmap-popup-links { margin-top: 8px; display: flex; flex-wrap: wrap; gap: 4px; }

/* ================================================================
   VENDOR PROFILE
   ================================================================ */

.budmap-vendor { max-width: 900px; margin: 0 auto; }

.budmap-vendor-header {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  background: var(--bd-navy);
  border-radius: var(--r-lg);
  margin-bottom: 16px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.budmap-vendor-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 95% -10%,
    rgba(45,212,170,.15) 0%, transparent 70%);
  pointer-events: none;
}

.budmap-vendor-header h2 {
  margin: 0 0 6px;
  font-size: 20px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.025em;
  position: relative;
  z-index: 1;
}

.budmap-vendor-logo img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.15);
  padding: 6px;
  position: relative;
  z-index: 1;
}

.budmap-vendor-header .budmap-actions { position: relative; z-index: 1; }
.budmap-vendor-header .budmap-link {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
  color: rgba(255,255,255,.85);
  font-size: 13px;
}
.budmap-vendor-header .budmap-link:hover { background: var(--bd-teal); border-color: var(--bd-teal); color: var(--bd-navy); }

.budmap-vendor-controls {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

.budmap-vendor-controls input[type=search] {
  width: 100%;
  padding: 11px 14px 11px 14px;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  font-size: 14px;
  font-family: var(--f);
  color: var(--c-text);
  background: var(--c-surface);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.budmap-vendor-controls input[type=search]:focus {
  border-color: var(--bd-teal);
  box-shadow: 0 0 0 3px var(--bd-teal-dim);
}

.budmap-vendor-controls .budmap-chip select {
  -webkit-appearance: none;
  appearance: none;
  background: var(--c-surface-2)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235a6e7d' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    right 10px center no-repeat;
  border-color: var(--c-border-md);
  color: var(--c-text);
}
.budmap-vendor-controls .budmap-chip select:focus,
.budmap-vendor-controls .budmap-chip select.active {
  border-color: var(--bd-teal);
  background-color: var(--bd-teal-lt);
  color: var(--bd-teal-dk);
}

.budmap-vendor-locations {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 10px;
}

.budmap-vendor-info {
  margin-top: 16px;
  padding: 14px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-surface-2);
}
.budmap-vendor-info h3 { margin: 0 0 8px; font-size: 16px; font-weight: 700; }
.budmap-vendor-info p  { margin: 0 0 6px; font-size: 14px; color: var(--c-muted); }

.budmap-vendor-description {
  font-size: 14px;
  line-height: 1.65;
  color: var(--c-muted);
  margin-bottom: 14px;
}

/* ================================================================
   ALERT SUBSCRIBE PROMPT
   ================================================================ */

.budmap-alert-prompt {
  position: relative;
  margin: 10px 14px;
  padding: 16px;
  background: var(--bd-teal-lt);
  border: 1px solid rgba(45,212,170,.3);
  border-radius: var(--r-lg);
  box-shadow: var(--e-1);
}
.budmap-alert-dismiss { position: absolute; top: 10px; right: 12px; background: none; border: none; font-size: 20px; cursor: pointer; color: var(--c-hint); }
.budmap-alert-icon  { font-size: 22px; margin-bottom: 6px; }
.budmap-alert-title { font-weight: 700; font-size: 14px; color: var(--c-ink); margin-bottom: 4px; }
.budmap-alert-sub   { font-size: 13px; color: var(--c-muted); margin-bottom: 12px; line-height: 1.5; }

.budmap-alert-form { display: flex; flex-wrap: wrap; gap: 6px; }
.budmap-alert-form input[type=email],
.budmap-alert-form input[type=text] {
  flex: 1 1 160px;
  padding: 10px 13px;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-family: var(--f);
  outline: none;
  background: var(--c-surface);
  transition: border-color var(--t);
}
.budmap-alert-form input:focus { border-color: var(--bd-teal); }
.budmap-alert-form select {
  padding: 10px 13px;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-family: var(--f);
  background: var(--c-surface);
  color: var(--c-text);
  outline: none;
}
.budmap-alert-msg { margin-top: 8px; font-size: 13px; color: var(--c-open); font-weight: 600; }

/* ================================================================
   STANDALONE ALERT WIDGET
   ================================================================ */

.budmap-alert-widget {
  background: var(--bd-teal-lt);
  border: 1.5px solid rgba(45,212,170,.3);
  border-radius: var(--r-xl);
  padding: 20px;
  max-width: 560px;
}
.budmap-alert-widget .budmap-alert-form { flex-direction: column; gap: 8px; margin-top: 10px; }
.budmap-alert-widget input,
.budmap-alert-widget select {
  width: 100%;
  padding: 12px 14px;
  font-size: 14px;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--c-border-md);
  font-family: var(--f);
  outline: none;
  background: var(--c-surface);
}
.budmap-alert-widget .budmap-btn { width: 100%; margin-top: 4px; }

/* ================================================================
   ZIP LOOKUP WIDGET
   ================================================================ */

.budmap-zip-widget { max-width: 560px; }
.budmap-zip-widget-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--c-ink);
  margin-bottom: 14px;
  letter-spacing: -.025em;
}
.budmap-zip-form { display: flex; gap: 8px; margin-bottom: 16px; }
.budmap-zip-input {
  flex: 1;
  max-width: 160px;
  padding: 12px 16px;
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  font-size: 15px;
  font-family: var(--f);
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.budmap-zip-input:focus { border-color: var(--bd-teal); box-shadow: 0 0 0 3px var(--bd-teal-dim); }
.budmap-zip-btn {
  padding: 12px 20px;
  border-radius: var(--r-pill);
  border: none;
  background: var(--bd-teal);
  color: var(--bd-navy);
  font-size: 14px;
  font-weight: 700;
  font-family: var(--f);
  cursor: pointer;
  transition: background var(--t);
}
.budmap-zip-btn:hover    { background: var(--bd-teal-dk); color: #fff; }
.budmap-zip-btn:disabled { opacity: .5; cursor: not-allowed; }
.budmap-zip-results { display: grid; grid-template-columns: 1fr; gap: 10px; }
.budmap-zip-error   { color: var(--c-cls); font-size: 13px; font-weight: 600; }
.budmap-zip-loading { color: var(--c-muted); font-size: 13px; }

/* ================================================================
   LEADERBOARD
   ================================================================ */

.budmap-leaderboard-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--c-ink);
  margin-bottom: 16px;
  letter-spacing: -.025em;
}
.budmap-leaderboard-list { display: flex; flex-direction: column; gap: 8px; }

.budmap-lb-item {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  background: var(--c-surface);
  overflow: hidden;
  box-shadow: var(--e-1);
  transition: box-shadow var(--t), border-color var(--t);
}
.budmap-lb-item:hover { box-shadow: var(--e-2); border-color: rgba(45,212,170,.3); }

.budmap-lb-left  { flex-shrink: 0; padding: 12px 0 12px 14px; }
.budmap-lb-logo  { width: 46px; height: 46px; object-fit: contain; border-radius: var(--r-sm); background: var(--c-surface-2); border: 1px solid var(--c-border); padding: 5px; }
.budmap-lb-rank  { width: 34px; height: 34px; border-radius: 50%; background: var(--bd-teal-lt); border: 1.5px solid rgba(45,212,170,.3); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; color: var(--bd-teal-dk); }
.budmap-lb-body  { flex: 1; min-width: 0; padding: 12px 0; }
.budmap-lb-name  { font-size: 14px; font-weight: 700; color: var(--c-ink); margin-bottom: 3px; letter-spacing: -.01em; }
.budmap-lb-name a { color: inherit; text-decoration: none; }
.budmap-lb-name a:hover { color: var(--bd-teal-dk); }
.budmap-lb-rating { font-size: 12px; color: var(--c-star); font-weight: 700; }
.budmap-lb-item > a.budmap-btn { margin-right: 14px; flex-shrink: 0; }

/* ================================================================
   RATING TRENDS
   ================================================================ */

.budmap-trends-row { padding: 12px 0; border-top: 1px solid var(--c-border); }
.budmap-trends-meta { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.budmap-trends-name { font-size: 13px; font-weight: 600; color: var(--c-text); }
.budmap-trends-rating { font-size: 13px; color: var(--c-star); font-weight: 700; }
.budmap-sparkline { display: block; width: 100%; height: 48px; }

/* ================================================================
   QR MODAL (sheet)
   ================================================================ */

.budmap-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(13,31,45,.65);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  display: none;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
}
.budmap-modal-overlay.open { display: flex; }
.budmap-modal-box {
  background: var(--c-surface);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: 6px 24px 32px;
  width: 100%;
  max-width: 440px;
  position: relative;
  box-shadow: var(--e-4);
  animation: bm-sheet-up .26s var(--ease) both;
}
@keyframes bm-sheet-up {
  from { transform: translateY(50px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.budmap-modal-box::before {
  content: '';
  display: block;
  width: 34px;
  height: 4px;
  border-radius: 2px;
  background: var(--c-border-md);
  margin: 10px auto 20px;
}
.budmap-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--c-surface-3);
  border: none;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  color: var(--c-muted);
  display: flex;
  align-items: center;
  justify-content: center;
}
.budmap-qr-body     { text-align: center; }
.budmap-qr-name     { font-weight: 800; font-size: 16px; color: var(--c-ink); margin-bottom: 4px; }
.budmap-qr-addr     { font-size: 13px; color: var(--c-muted); margin-bottom: 18px; }
.budmap-qr-img      { width: 200px; height: 200px; margin: 0 auto 18px; display: block; border: 1px solid var(--c-border); border-radius: var(--r-sm); }
.budmap-qr-actions  { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.budmap-qr-loading  { padding: 40px 0; color: var(--c-muted); }

/* ================================================================
   RESPONSIVE — TABLET 580px+
   ================================================================ */

@media (min-width: 580px) {
  .budmap-hero { padding: 18px 20px 22px; }
  .budmap-list {
    padding: 0 0 20px;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 12px;
  }
  .budmap-featured-grid { grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }
  .budmap-list-section { padding: 16px 16px 8px; }
  .budmap-vendor-locations { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
  .budmap-zip-results { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
  .budmap-alert-widget .budmap-alert-form { flex-direction: row; flex-wrap: wrap; }
  .budmap-alert-widget .budmap-btn { width: auto; }
  .budmap-modal-box { border-radius: var(--r-xl); margin: auto; max-width: 400px; }
  .budmap-modal-overlay { align-items: center; padding: 16px; }
}

/* ================================================================
   RESPONSIVE — DESKTOP 920px+
   ================================================================ */

@media (min-width: 920px) {
  .budmap-hero { padding: 20px 24px 24px; }
  .budmap-list-section { padding: 18px 24px 10px; }

  .budmap-controls {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap;
  }
  .budmap-search-row { flex: 1; min-width: 0; margin-bottom: 0; }
  .budmap-filter-chips { flex-wrap: nowrap; overflow-x: visible; }
  .budmap-chip-label { display: block; }
  .budmap-map { height: 460px; max-height: 580px; }

  .budmap-list {
    grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
    gap: 14px;
  }
  .budmap-featured-grid { grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); }

  .budmap-vendor-controls {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 8px;
  }
  .budmap-vendor-controls input[type=search] { flex: 1; min-width: 200px; }
}

@media (min-width: 1200px) {
  .budmap-list { grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); }
}

/* ================================================================
   SPONSORED LOCATIONS (Near Me only)
   ================================================================ */

.budmap-sponsored-section { margin-bottom: 16px; }

.budmap-sponsored-heading {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.budmap-sponsored-heading span {
  font-size: 12px;
  font-weight: 800;
  color: var(--bd-teal-dk);
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
}
.budmap-sponsored-heading::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(45,212,170,.35) 0%, transparent 100%);
}

.budmap-sponsored-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 580px) {
  .budmap-sponsored-grid { grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }
}
@media (min-width: 920px) {
  .budmap-sponsored-grid { grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); }
}

/* Sponsored card — teal left stripe + subtle teal wash */
.budmap-card--sponsored {
  border-color: rgba(45,212,170,.4);
  box-shadow: inset 3px 0 0 var(--bd-teal), var(--e-2);
  background: linear-gradient(135deg, #f0fdf9 0%, #fff 60%);
}
.budmap-card--sponsored:hover {
  border-color: var(--bd-teal);
  box-shadow: inset 3px 0 0 var(--bd-teal), 0 6px 20px rgba(45,212,170,.15);
}

/* Sponsored badge pill */
.budmap-sponsored-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: var(--bd-teal-lt);
  color: var(--bd-teal-dk);
  border: 1px solid rgba(45,212,170,.35);
  margin-left: 5px;
  vertical-align: middle;
  flex-shrink: 0;
}

/* Admin form label */
.buddash-sponsored-toggle {
  font-size: 13px;
  font-weight: 600;
  color: var(--bd-teal-dk, #1db896);
}
