/* ==========================================================================
   SALTROVE — TASK 19 — Interactive Map page
   Enqueued only when is_page_template('page-map.php').
   ========================================================================== */

.sr-map-page { background: var(--sr-paper); }

.sr-map-page__intro {
    padding: var(--sr-space-12) 0 var(--sr-space-6);
}
.sr-map-page__title {
    font-family: var(--sr-font-display);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.05;
    letter-spacing: var(--sr-ls-display);
    color: var(--sr-ink);
    margin: var(--sr-space-3) 0 var(--sr-space-4);
    font-weight: 500;
}
.sr-map-page__lede {
    font-family: var(--sr-font-display);
    font-size: 1.25rem;
    line-height: 1.5;
    color: var(--sr-charcoal);
    max-width: 600px;
}

/* ---- Map container ------------------------------------------------------ */
.sr-map-page__map-section {
    padding: var(--sr-space-4) 0 var(--sr-space-12);
}
.sr-map {
    /* Task 19b — height forced with !important as belt-and-braces against any
       upstream CSS (page templates, theme overrides, plugins) that might try
       to collapse the Leaflet container to zero. Inline `style` on the <div>
       is the third layer of defense. */
    width: 100% !important;
    height: 620px !important;
    min-height: 480px !important;
    border-radius: 4px;
    background: var(--sr-cream);
    border: 1px solid var(--sr-line);
    overflow: hidden;
    isolation: isolate;
}
@media (max-width: 800px) {
    .sr-map { height: 480px !important; }
}

.sr-map-page__meta {
    margin-top: var(--sr-space-4);
    font-size: var(--sr-fs-small);
    color: var(--sr-muted);
    text-align: center;
}
.sr-map-page__count {
    font-family: var(--sr-font-display);
    font-size: 1.125rem;
    color: var(--sr-gold);
    font-weight: 600;
    margin-right: 4px;
}

/* ---- Tile palette — warm the OSM tiles to match the site -------------- */
.sr-map-tiles {
    filter: sepia(0.15) saturate(0.75) brightness(0.98) hue-rotate(-10deg);
}

/* ---- Brass pin marker -------------------------------------------------- */
.sr-map-pin {
    position: relative;
    width: 18px;
    height: 18px;
}
.sr-map-pin__dot {
    position: absolute;
    inset: 0;
    background: var(--sr-gold);
    border: 2px solid var(--sr-paper);
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(14, 26, 43, 0.35);
    z-index: 2;
}
.sr-map-pin__pulse {
    position: absolute;
    inset: 0;
    background: var(--sr-gold);
    border-radius: 50%;
    animation: sr-pin-pulse 2200ms ease-out infinite;
    opacity: 0.5;
    z-index: 1;
}
@keyframes sr-pin-pulse {
    0%   { transform: scale(1);   opacity: 0.6; }
    100% { transform: scale(2.6); opacity: 0; }
}

/* ---- Leaflet popup overrides ------------------------------------------ */
.leaflet-popup-content-wrapper {
    background: transparent;
    box-shadow: 0 16px 40px -12px rgba(14, 26, 43, 0.35);
    padding: 0;
    border-radius: 4px;
    overflow: hidden;
}
.leaflet-popup-content {
    margin: 0;
    width: 260px !important;
}
.leaflet-popup-tip {
    background: var(--sr-paper);
}

.sr-map-popup {
    display: block;
    background: var(--sr-paper);
    border: 1px solid var(--sr-gold);
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    color: var(--sr-ink);
    transition: transform 250ms ease;
}
.sr-map-popup:hover { transform: translateY(-2px); }
.sr-map-popup__image {
    width: 100%;
    height: 130px;
    background-size: cover;
    background-position: center;
}
.sr-map-popup__body {
    padding: var(--sr-space-3) var(--sr-space-4) var(--sr-space-4);
}
.sr-map-popup__kicker {
    font-size: var(--sr-fs-micro);
    text-transform: uppercase;
    letter-spacing: var(--sr-ls-caps);
    color: var(--sr-gold);
    font-weight: 600;
}
.sr-map-popup__title {
    font-family: var(--sr-font-display);
    font-size: 1.125rem;
    line-height: 1.2;
    color: var(--sr-ink);
    margin: var(--sr-space-1) 0 var(--sr-space-2);
    font-weight: 500;
}
.sr-map-popup__read {
    font-size: var(--sr-fs-micro);
    text-transform: uppercase;
    letter-spacing: var(--sr-ls-caps);
    color: var(--sr-gold);
    font-weight: 600;
}

/* ---- List below map --------------------------------------------------- */
.sr-map-page__list {
    padding: var(--sr-space-12) 0;
    background: var(--sr-cream);
    border-top: 1px solid var(--sr-line);
}
.sr-map-page__list-grid {
    list-style: none;
    padding: 0;
    margin: var(--sr-space-6) 0 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sr-space-5);
}
.sr-map-page__list-link {
    display: block;
    background: var(--sr-paper);
    border: 1px solid var(--sr-line);
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    color: var(--sr-ink);
    transition: transform 280ms ease, box-shadow 280ms ease;
}
.sr-map-page__list-link:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 30px -10px rgba(184, 137, 74, 0.35);
}
.sr-map-page__list-image {
    width: 100%;
    height: 160px;
    background-size: cover;
    background-position: center;
}
.sr-map-page__list-body {
    padding: var(--sr-space-4);
}
.sr-map-page__list-title {
    font-family: var(--sr-font-display);
    font-size: 1.125rem;
    line-height: 1.25;
    color: var(--sr-ink);
    margin: var(--sr-space-1) 0 0;
    font-weight: 500;
}

/* ---- Reduced motion --------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .sr-map-pin__pulse { animation: none; display: none; }
    .sr-map-popup:hover { transform: none; }
    .sr-map-page__list-link:hover { transform: none; }
}

/* ==========================================================================
   TASK 20 — Mobile responsive (map page) — refines Task 19's 800px rule
   ========================================================================== */
@media (max-width: 800px) {
    .sr-map { height: 420px !important; min-height: 320px !important; }
    .sr-map-page__title { font-size: clamp(2rem, 8vw, 3rem); }
    .sr-map-page__list-grid { grid-template-columns: 1fr !important; }
}
