/* ============================================================
   page-directory.css
   Archive template for gd_place (the /directory/ page).

   Ported from canonical-specs/mockups/mentioned-directory-browse.html
   inline <style> block. Conversions applied:
     - All raw color/radius literals → --mn-* tokens (style.css)
     - .hero / .card / .btn → .mn-* prefixed selectors
     - Everything scoped under .mn-body to defend against plugin/theme leaks
     - Asymmetric corner system enforced (--mn-r-card large + sharp BR;
       --mn-r-input / --mn-r-badge / --mn-r-chip small + sharp TR;
       --mn-r-btn pill + sharp BR)

   Enqueued at priority 30 from inside archive-gd_place.php
   (same pattern as front-page.php enqueues page-home.css).

   Phase 3+ TODO:
     - Add styles for the Map view container (currently hidden in Phase 2)
     - Animate the Active-filter chips on add/remove (CSS transitions
       are wired but the JS chip-removal isn't)
     - Tighten breakpoints once seed content reveals real card-density edge
       cases
   ============================================================ */


/* ─── HERO ─────────────────────────────────────────────── */

.mn-body .mn-dir-hero {
  background: var(--mn-cream);
  padding: 88px var(--mn-container-pad) 48px;
}
.mn-body .mn-dir-hero__inner {
  max-width: var(--mn-container-max);
  margin: 0 auto;
}
.mn-body .mn-dir-hero .mn-eyebrow {
  font-family: var(--mn-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mn-teal-mid);
  margin-bottom: 1.25rem;
  display: block;
}
.mn-body .mn-dir-hero__h1 {
  font-family: var(--mn-font-display);
  font-weight: 500;
  font-size: 80px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--mn-forest);
  margin-bottom: 1.25rem;
  text-transform: uppercase;
  max-width: 900px;
}
.mn-body .mn-dir-hero__h1 .mn-accent {
  font-size: 78px;
  text-transform: none;
  letter-spacing: -0.015em;
}
.mn-body .mn-dir-hero__lede {
  font-family: var(--mn-font-body);
  font-size: 17px;
  font-weight: 400;
  line-height: 1.65;
  color: var(--mn-ink-mid);
  max-width: 620px;
}


/* ─── COMMUNITY FILTER STRIP ──────────────────────────── */

.mn-body .mn-dir-filters {
  background: var(--mn-cream);
  padding: 24px var(--mn-container-pad) 48px;
  border-bottom: 0.5px solid var(--mn-hairline);
}
.mn-body .mn-dir-filters__inner {
  max-width: var(--mn-container-max);
  margin: 0 auto;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.mn-body .mn-comm-pill {
  font-family: var(--mn-font-body);
  font-size: 14px;
  font-weight: 400;
  padding: 9px 20px;
  border-radius: var(--mn-r-chip);
  border: 0.5px solid var(--mn-hairline);
  color: var(--mn-ink-mid);
  cursor: pointer;
  background: var(--mn-paper);
  text-decoration: none;
  line-height: 1.2;
  display: inline-block;
}
.mn-body .mn-comm-pill:hover {
  border-color: var(--mn-forest);
  color: var(--mn-forest);
}
.mn-body .mn-comm-pill.is-on {
  background: var(--mn-forest);
  color: var(--mn-teal-lighter);
  border-color: var(--mn-forest);
}


/* ─── TWO-COLUMN SHELL ───────────────────────────────── */

.mn-body .mn-dir-shell {
  background: var(--mn-cream);
  padding: 48px var(--mn-container-pad) 96px;
}
.mn-body .mn-dir-shell__inner {
  max-width: var(--mn-container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 48px;
  align-items: flex-start;
}


/* ─── SIDEBAR ────────────────────────────────────────── */

.mn-body .mn-dir-sidebar {
  position: sticky;
  top: 104px;
  background: var(--mn-paper);
  border: 0.5px solid var(--mn-hairline);
  border-radius: var(--mn-r-card);
  padding: 28px;
}
.mn-body .mn-dir-sidebar__form { display: flex; flex-direction: column; gap: 0; }
.mn-body .mn-dir-sidebar__title {
  font-family: var(--mn-font-body);
  font-style:normal;
  font-weight: 500;
  font-size: 18px;
  color: var(--mn-forest);
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 0.5px solid var(--mn-hairline);
}
.mn-body .mn-filter-group { margin-bottom: 24px; }
.mn-body .mn-filter-group:last-of-type { margin-bottom: 0; }
.mn-body .mn-filter-group__label {
  font-family: var(--mn-font-body);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mn-teal-mid);
  margin-bottom: 10px;
  display: block;
}
.mn-body .mn-filter-select {
  width: 100%;
  padding: 11px 34px 11px 14px;
  background: var(--mn-cream);
  border: 0.5px solid var(--mn-hairline);
  border-radius: var(--mn-r-input);
  font-family: var(--mn-font-body);
  font-size: 14px;
  color: var(--mn-ink);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%23718096' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
}
.mn-body .mn-filter-select:focus {
  outline: none;
  border-color: var(--mn-teal-mid);
}

/* Claimed-only toggle (visual switch backed by a checkbox) */
.mn-body .mn-filter-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 8px 0;
}
.mn-body .mn-filter-toggle input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.mn-body .mn-toggle-switch {
  width: 36px;
  height: 20px;
  background: var(--mn-hairline);
  border-radius: 999px;
  position: relative;
  flex-shrink: 0;
}
.mn-body .mn-toggle-switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: var(--mn-paper);
  border-radius: 50%;
  transition: transform 0.3s var(--mn-ease);
}
.mn-body .mn-filter-toggle input[type="checkbox"]:checked + .mn-toggle-switch,
.mn-body .mn-toggle-switch.is-on { background: var(--mn-forest); }
.mn-body .mn-filter-toggle input[type="checkbox"]:checked + .mn-toggle-switch::after,
.mn-body .mn-toggle-switch.is-on::after { transform: translateX(16px); }
.mn-body .mn-filter-toggle input[type="checkbox"]:focus-visible + .mn-toggle-switch { outline: 2px solid var(--mn-teal-mid); outline-offset: 2px; }
.mn-body .mn-toggle-label {
  font-family: var(--mn-font-body);
  font-size: 14px;
  color: var(--mn-ink);
}

/* Grid/Map view toggle */
.mn-body .mn-view-toggle {
  display: flex;
  background: var(--mn-cream);
  border-radius: var(--mn-r-input);
  padding: 4px;
  border: 0.5px solid var(--mn-hairline);
}
.mn-body .mn-view-toggle button {
  flex: 1;
  padding: 9px;
  background: transparent;
  border: none;
  font-family: var(--mn-font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-ink-mid);
  cursor: pointer;
  border-radius: 10px 0 10px 10px;
}
.mn-body .mn-view-toggle button.is-on {
  background: var(--mn-forest);
  color: var(--mn-cream);
}

/* Apply submit */
.mn-body .mn-filter-apply {
  margin-top: 8px;
  background: var(--mn-forest);
  color: var(--mn-cream);
  border: none;
  font-family: var(--mn-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 12px;
  border-radius: var(--mn-r-btn);
  cursor: pointer;
}
.mn-body .mn-filter-apply:hover {
  background: var(--mn-forest-soft);
  transform: translateY(-2px);
}

/* Active filters chips */
.mn-body .mn-active-filters {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 0.5px solid var(--mn-hairline);
}
.mn-body .mn-active-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--mn-mint);
  color: var(--mn-forest);
  font-family: var(--mn-font-body);
  font-size: 12px;
  padding: 5px 10px;
  border-radius: var(--mn-r-badge);
  margin-right: 4px;
  margin-bottom: 4px;
  text-decoration: none;
}
.mn-body .mn-active-chip span {
  font-weight: 500;
  color: var(--mn-forest-soft);
}
.mn-body .mn-active-chip:hover {
  background: var(--mn-teal-lighter);
  color: var(--mn-forest);
}


/* ─── MAIN CONTENT ───────────────────────────────────── */

.mn-body .mn-dir-main { min-width: 0; }

.mn-body .mn-results-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 28px;
  padding-bottom: 18px;
  border-bottom: 0.5px solid var(--mn-hairline);
  gap: 16px;
  flex-wrap: wrap;
}
.mn-body .mn-results-count {
  font-family: var(--mn-font-body);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--mn-forest);
}
.mn-body .mn-results-count em {
  font-family: var(--mn-font-body);
  font-style:normal;
  color: var(--mn-teal-mid);
  font-size: 15px;
  text-transform: none;
  font-weight: 400;
  letter-spacing: -0.005em;
}
.mn-body .mn-sort-by {
  font-family: var(--mn-font-body);
  font-size: 13px;
  color: var(--mn-ink-mid);
  font-style:normal;
}
.mn-body .mn-sort-by strong {
  color: var(--mn-forest);
  font-style: normal;
  font-weight: 500;
}


/* ─── LISTING CARDS GRID ─────────────────────────────── */

.mn-body .mn-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

/* Card visual base — extends the .mn-card pattern from page-home.css
   (lines 445-528). We use a sibling class .mn-listing-card so the
   homepage cards keep their bespoke padding and this archive card
   can vary independently in future. */
.mn-body .mn-listing-card {
  background: var(--mn-paper);
  border: 0.5px solid var(--mn-hairline);
  border-radius: var(--mn-r-card);
  padding: 28px;
  cursor: pointer;
  color: inherit;
  display: block;
  position: relative;
  text-decoration: none;
}
.mn-body .mn-listing-card:hover {
  transform: translateY(-6px);
  border-color: rgba(29, 158, 117, 0.3);
  background: rgba(29, 158, 117, 0.04);
}
.mn-body .mn-listing-card__eyebrow {
  font-family: var(--mn-font-body);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mn-ink-mid);
  margin-bottom: 12px;
}
.mn-body .mn-listing-card__name {
  font-family: var(--mn-font-body);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--mn-forest);
  margin-bottom: 6px;
  text-transform: uppercase;
}
.mn-body .mn-listing-card__loc {
  font-family: var(--mn-font-body);
  font-style:normal;
  font-size: 13px;
  color: var(--mn-ink-mid);
  margin-bottom: 22px;
}
.mn-body .mn-listing-card__stats {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 16px;
  border-top: 0.5px solid var(--mn-hairline);
}
.mn-body .mn-listing-card__stat {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--mn-font-body);
  font-size: 12px;
  color: var(--mn-ink-mid);
}
.mn-body .mn-listing-card__stat-v {
  font-family: var(--mn-font-display);
  font-weight: 500;
  font-size: 18px;
  color: var(--mn-forest);
  line-height: 1;
}
.mn-body .mn-listing-card__stat-v em {
  font-family: var(--mn-font-body);
  font-style:normal;
  color: var(--mn-teal-mid);
  font-weight: 400;
  font-size: 19px;
}
.mn-body .mn-listing-card__tag {
  font-family: var(--mn-font-body);
  display: inline-block;
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mn-teal-mid);
  background: rgba(29, 158, 117, 0.1);
  padding: 5px 11px;
  border-radius: var(--mn-r-badge);
  margin-top: 18px;
}

/* Ghost variant */
.mn-body .mn-listing-card.is-ghost .mn-listing-card__tag,
.mn-body .mn-listing-card .mn-listing-card__tag.is-unclaimed {
  color: var(--mn-ink-soft);
  background: var(--mn-cream-warm);
}
.mn-body .mn-listing-card.is-ghost .mn-listing-card__stat-v,
.mn-body .mn-listing-card.is-ghost .mn-listing-card__stat-v em {
  color: var(--mn-ink-soft);
}

/* Pro variant — discreet badge in the (otherwise sharp) top-right corner */
.mn-body .mn-listing-card.is-pro::after {
  content: 'PRO';
  position: absolute;
  top: -1px;
  right: -1px;
  background: var(--mn-coral);
  color: var(--mn-coral-light);
  font-family: var(--mn-font-body);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.18em;
  padding: 6px 12px;
  /* Mirrors the parent corner: large/sharp on BR + the small/sharp TR via
     a coral wedge. Asymmetry preserved. */
  border-radius: 0 var(--mn-r-card) 0 var(--mn-r-badge);
}


/* ─── PAGINATION ─────────────────────────────────────── */

.mn-body .mn-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 0.5px solid var(--mn-hairline);
  flex-wrap: wrap;
}
.mn-body .mn-pagination__btn,
.mn-body .mn-pagination .prev.mn-pagination__btn,
.mn-body .mn-pagination .next.mn-pagination__btn {
  font-family: var(--mn-font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-forest);
  background: transparent;
  border: 0.5px solid var(--mn-hairline);
  padding: 11px 22px;
  border-radius: var(--mn-r-btn);
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.mn-body .mn-pagination__btn:hover {
  border-color: var(--mn-forest);
  transform: translateY(-2px);
}
.mn-body .mn-pagination .mn-page-num {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mn-font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--mn-ink-mid);
  background: transparent;
  border: 0.5px solid transparent;
  cursor: pointer;
  border-radius: var(--mn-r-input);
  text-decoration: none;
}
.mn-body .mn-pagination .mn-page-num:hover {
  color: var(--mn-forest);
  border-color: var(--mn-hairline);
}
.mn-body .mn-pagination .mn-page-num.current {
  background: var(--mn-forest);
  color: var(--mn-cream);
  border-color: var(--mn-forest);
}


/* ─── EMPTY STATE ────────────────────────────────────── */

.mn-body .mn-empty-state {
  background: var(--mn-paper);
  border: 0.5px solid var(--mn-hairline);
  border-radius: var(--mn-r-card);
  padding: 64px 40px;
  text-align: center;
}
.mn-body .mn-empty-state__h2 {
  font-family: var(--mn-font-display);
  font-size: 36px;
  text-transform: uppercase;
  color: var(--mn-forest);
  margin-bottom: 12px;
}
.mn-body .mn-empty-state__p {
  font-family: var(--mn-font-body);
  font-size: 15px;
  font-style:normal;
  color: var(--mn-ink-mid);
  margin-bottom: 24px;
}


/* ─── RESPONSIVE ─────────────────────────────────────── */

@media (max-width: 960px) {
  .mn-body .mn-dir-hero { padding: 64px var(--mn-container-pad) 32px; }
  .mn-body .mn-dir-hero__h1 { font-size: 54px; }
  .mn-body .mn-dir-hero__h1 .mn-accent { font-size: 52px; }

  .mn-body .mn-dir-filters { padding: 16px var(--mn-container-pad) 32px; }

  .mn-body .mn-dir-shell { padding: 32px var(--mn-container-pad) 64px; }
  .mn-body .mn-dir-shell__inner { grid-template-columns: 1fr; gap: 24px; }
  .mn-body .mn-dir-sidebar { position: static; padding: 20px; }

  .mn-body .mn-cards-grid { grid-template-columns: 1fr; }

  .mn-body .mn-results-header { align-items: flex-start; flex-direction: column; gap: 8px; }
}

@media (min-width: 961px) and (max-width: 1180px) {
  .mn-body .mn-cards-grid { grid-template-columns: repeat(2, 1fr); }
}
