/* ============================================================
   Dealer Locator — Map-first layout
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;600;700;800&display=swap');

/* ── Break out of Astra container constraints ─────────────── */
.page-template-page-dealers-php .ast-container,
.page-template-page-dealers-php #content .ast-container,
.dl-fullwidth-page .ast-container,
.dl-fullwidth-page #content .ast-container {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.page-template-page-dealers-php #primary,
.page-template-page-dealers-php #content,
.page-template-page-dealers-php .content-area,
.dl-fullwidth-page #primary,
.dl-fullwidth-page #content,
.dl-fullwidth-page .content-area {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.page-template-page-dealers-php .ast-article-single,
.page-template-page-dealers-php .entry-content,
.page-template-page-dealers-php .post-content,
.dl-fullwidth-page .ast-article-single,
.dl-fullwidth-page .entry-content,
.dl-fullwidth-page .post-content {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.page-template-page-dealers-php .ast-grid-right-inner-wrap,
.page-template-page-dealers-php .ast-grid-left-inner-wrap,
.dl-fullwidth-page .ast-grid-right-inner-wrap,
.dl-fullwidth-page .ast-grid-left-inner-wrap {
    width: 100% !important;
    max-width: 100% !important;
}

/* ── Page wrapper — scope variables here to beat plugin :root ─ */
.dl-page {
    --dl-dark    : #1a1a1a;
    --dl-red     : #cc0000;
    --dl-border  : #e0e0e0;
    --dl-text    : #333;
    --dl-muted   : #888;
    --dl-white   : #fff;
    --dl-bg-bar  : #222;
    --dl-sidebar : #f7f7f7;

    font-family: "Be Vietnam Pro", sans-serif !important;
    color: var(--dl-text);
    position: relative;
    z-index: 1;
}

/* Apply Be Vietnam Pro to all children — override Astra global font */
.dl-page *,
.dl-page *::before,
.dl-page *::after {
    font-family: "Be Vietnam Pro", sans-serif !important;
    box-sizing: border-box;
}

.dl-page-title {
    font-size: clamp(18px, 2.5vw, 26px) !important;
    font-weight: 800 !important;
    color: var(--dl-dark) !important;
    margin: 0 !important;
    padding: 24px 28px 16px 0 !important;
    letter-spacing: .03em !important;
    line-height: 1.2 !important;
    text-transform: none !important;
	text-align: center !important;
}

/* ── Search panel ─────────────────────────────────────────── */
.dl-search-panel {
    display: flex;
    gap: 0;
    background: var(--dl-bg-bar);
    padding: 18px 28px;
}

.dl-search-col {
    flex: 1;
    padding-right: 24px;
    border-right: 1px solid #444;
}

.dl-search-col--locate {
    flex: 0 0 auto;
    border-right: none;
    padding-right: 0;
    padding-left: 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.dl-search-label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #aaa !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    margin-bottom: 8px !important;
    line-height: 1.2 !important;
}

.dl-input-wrap { display: flex; }

.dl-input {
    flex: 1;
    padding: 9px 12px;
    border: none !important;
    border-bottom: 2px solid #555 !important;
    background: transparent !important;
    color: var(--dl-white) !important;
    font-size: 14px !important;
    outline: none;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.dl-input::placeholder { color: #666; }
.dl-input:focus { border-bottom-color: var(--dl-red) !important; }

.dl-btn-search {
    padding: 9px 16px !important;
    background: var(--dl-red) !important;
    color: var(--dl-white) !important;
    border: none !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    letter-spacing: .05em !important;
    white-space: nowrap !important;
    transition: background .15s !important;
    text-transform: none !important;
    border-radius: 0 !important;
    line-height: 1 !important;
}

.dl-btn-search:hover { background: #a80000 !important; }

.dl-btn-locate {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 9px 16px !important;
    background: transparent !important;
    color: var(--dl-white) !important;
    border: 2px solid #555 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    letter-spacing: .05em !important;
    transition: border-color .15s, color .15s !important;
    text-transform: none !important;
    border-radius: 0 !important;
    line-height: 1 !important;
}

.dl-btn-locate:hover { border-color: var(--dl-red) !important; color: var(--dl-red) !important; }

/* Pulse hint when geolocation needs manual approval */
@keyframes dl-locate-pulse {
    0%, 100% { border-color: #555; box-shadow: none; }
    50%       { border-color: var(--dl-red); color: var(--dl-red); box-shadow: 0 0 0 4px rgba(196,30,58,.2); }
}
.dl-btn-locate.is-locate-hint {
    animation: dl-locate-pulse 1.2s ease-in-out 3;
}

/* ── Split layout ─────────────────────────────────────────── */
.dl-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    height: 620px;
}

/* ── Sidebar ──────────────────────────────────────────────── */
.dl-sidebar {
    background: var(--dl-sidebar);
    border-right: 1px solid var(--dl-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.dl-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border-bottom: 1px solid var(--dl-border);
    background: var(--dl-white);
    flex-shrink: 0;
}

.dl-sidebar-count {
    font-size: 12px !important;
    color: var(--dl-muted) !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
}

.dl-show-all {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--dl-red) !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    letter-spacing: .04em !important;
    padding: 2px 0 !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.dl-show-all:hover { text-decoration: underline; }

.dl-region-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

.dl-region-list::-webkit-scrollbar { width: 4px; }
.dl-region-list::-webkit-scrollbar-track { background: transparent; }
.dl-region-list::-webkit-scrollbar-thumb { background: #ccc; border-radius: 2px; }

.dl-region-group { margin-bottom: 4px; }

/* h3 reset — Astra sets h3 to large sizes, override completely */
.dl-region-label,
h3.dl-region-label {
    font-size: 10px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    color: var(--dl-white) !important;
    background: var(--dl-dark) !important;
    padding: 6px 14px !important;
    margin: 0 !important;
    border: none !important;
}

/* button reset — Astra/Elementor may set uppercase, large padding, rounded */
.dl-province-btn,
button.dl-province-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    padding: 8px 14px !important;
    background: none !important;
    border: none !important;
    border-bottom: 1px solid var(--dl-border) !important;
    text-align: left !important;
    cursor: pointer !important;
    transition: background .12s !important;
    gap: 8px !important;
    text-transform: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    line-height: 1 !important;
    outline: none !important;
}

.dl-province-btn:hover { background: #ebebeb !important; }

.dl-province-btn.is-active {
    background: var(--dl-red) !important;
}

.dl-province-btn.is-active .dl-province-name { color: var(--dl-white) !important; }
.dl-province-btn.is-active .dl-province-count { background: rgba(255,255,255,.25) !important; color: var(--dl-white) !important; }

.dl-province-name {
    font-size: 13px !important;
    color: var(--dl-text) !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
}

.dl-province-count {
    flex-shrink: 0 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--dl-muted) !important;
    background: var(--dl-border) !important;
    border-radius: 10px !important;
    padding: 1px 7px !important;
    min-width: 22px !important;
    text-align: center !important;
    line-height: 1.6 !important;
}

.dl-sidebar-hint {
    font-size: 12px !important;
    color: var(--dl-muted) !important;
    padding: 16px 14px !important;
    line-height: 1.6 !important;
}

/* ── Map ──────────────────────────────────────────────────── */
.dl-map-wrap {
    position: relative;
    isolation: isolate;
    height: 100%;
}

#dl-leaflet-map {
    width: 100%;
    height: 620px;
}

/* Hide Google Maps auth-error overlay (localhost only) */
#dl-leaflet-map .gm-err-container,
#dl-leaflet-map [class*="gm-err"] { display: none !important; }

/* ── Custom pin ───────────────────────────────────────────── */
.dl-pin {
    width: 22px;
    height: 32px;
    background: var(--dl-dark);
    clip-path: polygon(50% 100%, 0% 30%, 15% 0%, 85% 0%, 100% 30%);
    transition: background .15s;
}

.dl-pin--priority { background: var(--dl-red); }

/* ── Leaflet popup ────────────────────────────────────────── */
.dl-popup-wrap .leaflet-popup-content-wrapper {
    border-radius: 2px;
    padding: 0;
    box-shadow: 0 3px 14px rgba(0,0,0,.25);
    border-top: 3px solid var(--dl-red);
}

.dl-popup-wrap .leaflet-popup-content { margin: 0; }

.dl-popup {
    padding: 14px 16px;
    min-width: 220px;
}

.dl-popup-name {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--dl-dark) !important;
    margin-bottom: 6px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 6px !important;
    line-height: 1.3 !important;
    text-transform: none !important;
}

.dl-popup-badge {
    font-size: 9px !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    background: var(--dl-dark) !important;
    color: var(--dl-white) !important;
    padding: 2px 6px !important;
    border-radius: 2px !important;
    white-space: nowrap !important;
    text-transform: uppercase !important;
}

.dl-popup-address {
    font-size: 12px !important;
    color: var(--dl-muted) !important;
    margin-bottom: 5px !important;
    line-height: 1.5 !important;
}

.dl-popup-phone {
    display: block !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--dl-dark) !important;
    text-decoration: none !important;
    margin-bottom: 3px !important;
}

.dl-popup-phone:hover { color: var(--dl-red) !important; }

.dl-popup-email {
    font-size: 11px !important;
    color: var(--dl-muted) !important;
    margin-bottom: 8px !important;
}

.dl-popup-actions {
    display: flex !important;
    gap: 6px !important;
    margin-top: 10px !important;
    padding-top: 10px !important;
    border-top: 1px solid var(--dl-border) !important;
}

.dl-popup-action {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    padding: 5px 10px !important;
    text-decoration: none !important;
    border: 1px solid var(--dl-border) !important;
    color: var(--dl-dark) !important;
    transition: background .12s, color .12s, border-color .12s !important;
    text-transform: none !important;
    border-radius: 0 !important;
}

.dl-popup-action--map:hover {
    background: var(--dl-dark) !important;
    color: var(--dl-white) !important;
    border-color: var(--dl-dark) !important;
}

.dl-popup-action--site:hover {
    background: #3d8bcd !important;
    color: var(--dl-white) !important;
    border-color: #3d8bcd !important;
}

/* ── Dealer list ──────────────────────────────────────────── */
.dl-dealer-list {
    padding: 28px 28px 40px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
    border-top: 1px solid var(--dl-border);
}

.dl-dealer-card {
    background: var(--dl-white);
    border: 1px solid var(--dl-border);
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    transition: border-color .15s, box-shadow .15s;
}

.dl-dealer-card:hover {
    border-color: #bbb;
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
}

.dl-card-name {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--dl-dark) !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
    line-height: 1.4 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.dl-card-badge {
    flex-shrink: 0 !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    background: var(--dl-red) !important;
    color: var(--dl-white) !important;
    padding: 2px 6px !important;
    border-radius: 2px !important;
    white-space: nowrap !important;
    margin-top: 1px !important;
    text-transform: uppercase !important;
}

.dl-card-addr {
    font-size: 12px !important;
    color: var(--dl-muted) !important;
    line-height: 1.5 !important;
    text-transform: none !important;
}

.dl-card-phone {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--dl-dark) !important;
    text-decoration: none !important;
}

.dl-card-phone:hover { color: var(--dl-red) !important; }

.dl-card-site {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--dl-muted) !important;
    text-decoration: none !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    margin-top: 4px !important;
}

.dl-card-site:hover { color: var(--dl-dark) !important; }

.dl-list-empty {
    grid-column: 1 / -1;
    font-size: 13px !important;
    color: var(--dl-muted) !important;
    padding: 8px 0 !important;
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 860px) {
    .dl-layout {
        grid-template-columns: 1fr;
        height: auto;
    }

    .dl-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--dl-border);
        max-height: 280px;
    }

    .dl-map-wrap { height: 420px; }
    #dl-leaflet-map { height: 420px; }
}

@media (max-width: 600px) {
    .dl-page-title { padding: 16px 16px 12px !important; }

    .dl-search-panel { flex-direction: column; gap: 16px; padding: 16px; }
    .dl-search-col { border-right: none; border-bottom: 1px solid #444; padding: 0 0 16px; }
    .dl-search-col--locate { border-bottom: none; padding: 0; }

    .dl-map-wrap { height: 360px; }
    #dl-leaflet-map { height: 360px; }
}

/* ── Slider layout ────────────────────────────────────────── */
  .dl-dealer-list[data-layout="slider"] {
      display: block;
      padding: 28px 28px 40px;
  }
  .dl-slider { display: flex; align-items: center; gap: 10px; }
  .dl-slider-viewport { flex: 1; overflow: hidden; cursor: grab; user-select: none; }
  .dl-slider-track { display: flex; transition: transform 0.3s ease; will-change: transform; }
  .dl-slider-track .dl-dealer-card { min-width: 0; flex-shrink: 0; margin: 0; }
  .dl-slider-btn {
      flex-shrink: 0 !important; width: 40px !important; height: 40px !important;
      background: var(--dl-dark) !important; color: var(--dl-white) !important;
      border: none !important; font-size: 28px !important; line-height: 1 !important;
      cursor: pointer !important; display: flex !important; align-items: center !important;
      justify-content: center !important; transition: background 0.15s, opacity 0.15s !important;
      border-radius: 0 !important; padding: 0 !important;
      text-transform: none !important; letter-spacing: 0 !important; box-shadow: none !important;
  }
  .dl-slider-btn:hover:not(:disabled) { background: var(--dl-red) !important; }
  .dl-slider-btn:disabled { cursor: default !important; }
  @media (max-width: 860px) {
      .dl-dealer-list[data-layout="slider"] { padding: 20px 16px 32px; }
  }
  @media (max-width: 600px) {
      .dl-dealer-list[data-layout="slider"] { padding: 16px 12px 28px; }
      .dl-slider-btn { width: 32px !important; height: 32px !important; font-size: 22px !important; }
  }
