/* ============================================================================
   ASK HAVA — DESERT MODERN: directory surfaces  (desert_directory.css)
   Page styles for the category browse pages (category_sandstone.html,
   category_trade.html), /categories index, the Phase-6 landing shells
   (category_landing.html, themed_group_landing.html, collection_landing.html),
   /search, and the /map chrome. Pairs with desert.css (tokens + chrome) via
   desert_base.html — load AFTER desert.css.

   Many selectors here keep their legacy class names on purpose: tests and JS
   pin them (cathead/crumb/chips/filterpill/sortpill/biz-grid/filtersummary/
   map-scope-tab/hava-card/…). We restyle, we do not rename.
   ========================================================================= */

/* legacy container alias — same metrics as .d-wrap. Classes sharing this
   element must only set padding-top/bottom (a `padding:X 0 Y` shorthand
   erases the side gutters — that was the mobile x=0 bug). */
.wrap{max-width:1280px;margin:0 auto;padding-left:32px;padding-right:32px}

/* ============================== category head (orange block + giant count)
   Kept SHORT on purpose: breadcrumb + H1 + one-line blurb + count. All the
   filter chips live below the orange block, on the page background. */
.cat-head{background:var(--orange);color:var(--black);position:relative;overflow:hidden}
.cat-head .cathead{
  position:relative;z-index:2;padding-top:40px;padding-bottom:46px;
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:30px;align-items:end;
}
.cat-head .crumb{
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  opacity:.72;margin-bottom:14px;
}
.cat-head .crumb a:hover{color:var(--cream)}
.cat-head h1{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(42px,6.5vw,88px);
  line-height:.92;letter-spacing:-.025em;text-transform:uppercase;
}
.cat-head p,
.cat-head .sub{margin-top:14px;font-size:clamp(15px,1.4vw,17.5px);font-weight:500;max-width:56ch}
/* giant listing count — cream numeral, black unit label (mockup .giant).
   ~64px on mobile: a number, not a billboard. */
.cat-head .giant{
  font-family:var(--disp);font-weight:800;
  font-size:clamp(64px,9vw,144px);line-height:.85;letter-spacing:-.04em;
  color:var(--cream);text-align:right;
}
.cat-head .giant small{
  display:block;font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;
  color:var(--black);text-align:right;margin-top:10px;
}
/* blue mountain ridge along the bottom edge */
.cat-head .ridge{
  position:absolute;left:-5%;right:-5%;bottom:-2px;height:36px;background:var(--blue);z-index:1;
  clip-path:polygon(0 70%,10% 35%,22% 62%,36% 22%,50% 58%,64% 18%,78% 52%,90% 30%,100% 44%,100% 100%,0 100%);
}

/* chip rows BELOW the orange head (subtypes / cuisine / trades) — quiet
   outline pills on the page background; the active chip flips to solid ink.
   The cuisine row stays a single horizontally-scrollable line. */
.cat-chips{padding-top:20px;padding-bottom:18px}
.cat-chips .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.cat-chips .chips:first-child{margin-top:0}
.cat-chips .chips .lbl{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  align-self:center;margin-right:4px;opacity:.55;white-space:nowrap;
}
.cat-chips .chip{
  display:inline-flex;align-items:center;gap:7px;flex:none;
  font-size:12.5px;font-weight:600;letter-spacing:0;white-space:nowrap;
  border:1.5px solid rgba(23,19,16,.45);border-radius:999px;padding:7px 15px;
  transition:background .15s,color .15s,border-color .15s;
}
.cat-chips .chip:hover{border-color:var(--black)}
.cat-chips .chip.on{background:var(--black);border-color:var(--black);color:var(--cream)}
.cat-chips .chip-n{
  font-family:var(--disp);font-weight:700;font-size:11px;line-height:1;opacity:.55;
}
.cat-chips .chip.on .chip-n{opacity:.8}
.cat-chips .chips-cuisine{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}
.cat-chips .chips-cuisine::-webkit-scrollbar{display:none}

/* ============================== sticky filter/sort chipbar (black) ========= */
.catbar .filterbar,
.catbar .sortbar{display:flex;align-items:center;gap:10px;flex:none}
.catbar .lbl{
  font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--peach);white-space:nowrap;
}
.catbar .filterpill,
.catbar .sortpill{
  font-size:12.5px;font-weight:700;letter-spacing:.05em;white-space:nowrap;
  border:1.5px solid rgba(251,244,230,.4);border-radius:999px;padding:8px 17px;
  color:var(--cream);transition:background .15s,color .15s,border-color .15s;
}
.catbar .filterpill:hover,
.catbar .sortpill:hover{border-color:var(--peach);color:var(--peach)}
.catbar .filterpill.on,
.catbar .sortpill.on{background:var(--cream);border-color:var(--cream);color:var(--black)}
.catbar .sortbar{margin-left:18px;padding-left:18px;border-left:1px solid rgba(251,244,230,.22)}
.catbar .sortnote{font-size:11.5px;font-weight:500;opacity:.55;white-space:nowrap}

/* honest active-filter summary line (sentence case — quiet meta, not a shout) */
.filtersummary{
  margin:22px 0 0;font-size:13px;font-weight:600;letter-spacing:0;
  opacity:.75;
}
.filtersummary .clearfilters{font-weight:700;border-bottom:2px solid currentColor;padding-bottom:1px}
.filtersummary .clearfilters:hover{color:var(--orange-deep)}

/* "Showing X–Y of N" line */
.pageinfo{
  margin:22px 0 14px;font-size:13px;font-weight:600;letter-spacing:0;opacity:.6;
}
.listwrap{padding-top:14px;padding-bottom:60px}
.listwrap .pageinfo:first-child,
.listwrap .filtersummary:first-child{margin-top:28px}

/* ============================== category sponsor — pinned, labeled ======== */
.spon-sec{padding:34px 0 6px}
.spon-panel{
  display:grid;grid-template-columns:1.4fr 1fr;border-radius:var(--d-radius-lg);overflow:hidden;
  border:var(--d-border-thick);box-shadow:var(--d-shadow-blue);
  background:var(--blue);color:var(--cream);
}
.spon-copy{padding:40px 40px 36px}
.spon-copy .spon{
  display:inline-block;background:var(--orange);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  padding:7px 14px;border-radius:999px;margin-bottom:18px;
}
.spon-copy h2{
  font-family:var(--disp);font-weight:800;font-size:clamp(26px,3vw,40px);
  line-height:.98;text-transform:uppercase;letter-spacing:-.02em;
}
.spon-copy p{font-size:15px;font-weight:500;max-width:50ch;margin:14px 0 0;opacity:.92}
.spon-copy .spon-go{
  display:inline-block;margin-top:22px;
  font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  border-bottom:3px solid var(--orange);padding-bottom:3px;
}
a.spon-panel:hover .spon-go{color:var(--peach)}
.spon-art{background:var(--blue-deep);min-height:200px;background-size:cover;background-position:center}
@media(max-width:840px){
  .spon-panel{grid-template-columns:1fr;box-shadow:7px 7px 0 var(--blue)}
  .spon-art{min-height:170px}
  .spon-copy{padding:28px 24px}
}

/* ============================== listing rows (.biz-grid / .biz) ===========
   The legacy grid of cards becomes the mockup's dense bordered row list. */
.biz-grid{
  margin-top:18px;
  background:var(--cream);border:var(--d-border);border-radius:var(--d-radius);
  overflow:hidden;
}
.biz-grid:empty{display:none}
.biz{
  display:grid;grid-template-columns:64px minmax(0,1fr) auto;gap:6px 20px;align-items:center;
  padding:16px 24px;border-top:1.5px solid rgba(23,19,16,.14);
  transition:background .12s;
}
.biz:first-child{border-top:none}
.biz:hover{background:var(--sand-light)}
/* Provider-less place card (no detail page) — non-interactive, no link cue. */
.biz--place{cursor:default}
.biz--place:hover{background:inherit}
.biz.is-hidden{display:none}
/* square thumb (was the card hero) */
.biz .img{
  width:64px;height:64px;border:2px solid var(--black);border-radius:12px;
  background-color:var(--sand);background-size:cover;background-position:center;
  position:relative;overflow:visible;
}
.biz .img .open{
  position:absolute;left:-6px;bottom:-7px;
  background:var(--orange);color:var(--black);border-radius:999px;
  font-size:8.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 8px;white-space:nowrap;
}
.biz .img .open.closed{background:var(--black);color:var(--cream);opacity:.85}
.biz .body{min-width:0}
.biz h3{
  font-family:var(--disp);font-weight:700;font-size:clamp(16px,1.6vw,19px);line-height:1.15;
  overflow-wrap:anywhere;
}
.biz .meta{display:flex;align-items:baseline;gap:8px;font-size:13px;font-weight:500;margin-top:3px}
.biz .stars{font-family:var(--disp);font-weight:800;font-size:14.5px;color:var(--orange-deep);white-space:nowrap}
.biz .meta>span:not(.stars):not(.noreviews){opacity:.6;font-size:12px}
.biz .noreviews{font-size:12px;font-weight:500;opacity:.55;letter-spacing:.03em}
.biz .loc{font-size:12.5px;font-weight:500;opacity:.68;margin-top:2px}
.biz .faraway{margin-left:8px;font-style:italic;opacity:.8}
.biz .typ{
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  opacity:.55;margin-top:4px;
}
@media(max-width:700px){
  .biz{grid-template-columns:52px minmax(0,1fr);padding:14px 16px}
  .biz .img{width:52px;height:52px}
}

/* ============================== pagination ================================ */
.pager{
  margin-top:24px;display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.pagepos{font-size:13px;font-weight:600;letter-spacing:0;opacity:.6}
.pagebtn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;letter-spacing:.02em;
  border:2px solid var(--black);border-radius:999px;padding:11px 22px;
  transition:background .15s,color .15s;
}
a.pagebtn:hover{background:var(--black);color:var(--cream)}
.pagebtn.is-off{opacity:.35;border-color:rgba(23,19,16,.4)}

/* quiet feedback + empty state */
.suggest-missing a,
.suggest-edit a{border-bottom:2px solid var(--orange);padding-bottom:1px}
.cal-empty{
  margin:48px auto;text-align:center;font-size:16px;font-weight:500;
}
.cal-empty a{color:var(--orange-deep);font-weight:700;border-bottom:2px solid var(--orange);padding-bottom:1px}

/* ============================== ask strip (blue) ========================== */
.askstrip{background:var(--blue);color:var(--cream);padding:52px 0 56px;margin-top:46px}
.askstrip-in{display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap}
.askstrip h2{
  font-family:var(--disp);font-weight:800;font-size:clamp(24px,3vw,38px);
  line-height:1;text-transform:uppercase;letter-spacing:-.01em;
}
.askstrip h2 em{font-style:normal;color:var(--peach)}
.askstrip form{display:flex;background:var(--cream);border-radius:12px;overflow:hidden;flex:1;min-width:260px;max-width:520px}
.askstrip input{
  flex:1;min-width:0;border:none;outline:none;background:transparent;
  font-family:var(--text);font-size:15px;color:var(--black);padding:15px 16px;
}
.askstrip input::placeholder{color:#716552}
.askstrip button{
  border:none;background:var(--orange-deep);color:var(--cream);cursor:pointer;
  padding:0 20px;font-family:var(--text);font-weight:700;font-size:14px;
  letter-spacing:.01em;
}
.askstrip button:hover{background:var(--orange-deep)}
@media(max-width:700px){.askstrip-in{flex-direction:column;align-items:stretch}}

/* ============================== trade landing extras ====================== */
.trade-intro{margin-top:14px;font-size:clamp(15px,1.4vw,17.5px);font-weight:500;max-width:62ch}
.trade-faq{margin-top:52px}
.trade-faq h2{
  font-family:var(--disp);font-weight:800;font-size:clamp(24px,3vw,36px);
  line-height:1;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:20px;
}
details.faq-item{
  background:var(--cream);border:var(--d-border);border-radius:var(--d-radius);
  margin-bottom:12px;overflow:hidden;
}
details.faq-item summary{
  list-style:none;cursor:pointer;padding:16px 22px;
  display:flex;align-items:center;gap:14px;
}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary::after{
  content:"+";margin-left:auto;font-family:var(--disp);font-weight:800;font-size:20px;
  color:var(--orange-deep);flex:none;
}
details.faq-item[open] summary{background:var(--sand);border-bottom:var(--d-border)}
details.faq-item[open] summary::after{content:"–"}
details.faq-item summary h3{
  font-family:var(--disp);font-weight:700;font-size:16.5px;line-height:1.2;display:inline;
}
details.faq-item>p{padding:16px 22px;font-size:14.5px}

/* ============================== /categories index ========================= */
.dx-head{background:var(--sand);border-bottom:var(--d-border-thick);padding:56px 0 50px}
.dx-head .d-eyebrow{color:var(--orange-deep);margin-bottom:14px}
.dx-sub{margin-top:16px;font-size:clamp(15px,1.4vw,17.5px);font-weight:500;max-width:52ch}
.dx-gridwrap{padding-top:44px;padding-bottom:64px}
.dx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dx-card{display:flex;flex-direction:column;padding:0;overflow:hidden}
.dx-peek{height:130px;background:var(--sand);border-bottom:var(--d-border);overflow:hidden}
.dx-peek img{width:100%;height:100%;object-fit:cover;display:block}
.dx-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.dx-name{
  font-family:var(--disp);font-weight:800;font-size:clamp(17px,1.8vw,21px);
  line-height:1.08;text-transform:uppercase;letter-spacing:.01em;
}
.dx-copy{font-size:13.5px;font-weight:500;opacity:.75}
.dx-count{margin-top:auto;align-self:flex-start}
.dx-count--empty{font-size:12px;font-weight:500;opacity:.6;font-style:italic}
@media(max-width:1080px){.dx-grid{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.dx-grid{grid-template-columns:1fr}}

/* ============================== landing shells (Phase 6.2 pages) ==========
   category_landing / themed_group_landing / collection_landing keep their
   data-wired markup; this block reskins it. */
.category-page{padding-bottom:90px}
.cat-head .cat-head-meta{
  margin-top:16px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.75;
}
.cat-head .cat-head-meta a{border-bottom:2px solid var(--black);padding-bottom:1px}
.cat-head .cat-head-meta a:hover{color:var(--cream);border-bottom-color:var(--cream)}
.themed-group-bundled{
  margin-top:10px;font-size:12px;font-weight:500;letter-spacing:.04em;opacity:.7;
}

.category-sparse-banner{
  margin:22px auto 0;max-width:1280px;padding:14px 32px;
  background:var(--sand);border-top:var(--d-border);border-bottom:var(--d-border);
  font-size:14px;font-weight:500;
}

/* search-the-catalog bar (search_bar.js wiring preserved) */
.hava-search-bar{margin:26px auto 0;max-width:1280px;padding:0 32px}
.directory-search-label{
  display:block;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange-deep);margin-bottom:8px;
}
.hava-search-row{
  display:flex;background:var(--cream);border:var(--d-border);border-radius:14px;overflow:hidden;
  max-width:560px;
}
.hava-search-input{
  flex:1;min-width:0;border:none;outline:none;background:transparent;
  font-family:var(--text);font-size:15px;color:var(--black);padding:13px 16px;
}
.hava-search-submit{
  border:none;background:var(--black);color:var(--cream);cursor:pointer;
  padding:0 20px;font-family:var(--text);font-weight:700;font-size:13px;
  letter-spacing:.01em;
}
.hava-search-submit:hover{background:var(--orange-deep)}
.hava-search-results{
  max-width:560px;margin-top:8px;background:var(--cream);
  border:var(--d-border);border-radius:14px;overflow:hidden;
}
.hava-search-results[hidden]{display:none}
.hava-search-hit{display:block;padding:11px 16px;border-top:1.5px solid rgba(23,19,16,.12)}
.hava-search-hit:first-child{border-top:none}
.hava-search-hit:hover{background:var(--sand-light)}
.hava-search-hit-name{font-weight:700;font-size:14.5px}
.hava-search-hit-meta{font-size:12px;opacity:.65}
.hava-search-results-empty{padding:11px 16px;font-size:13.5px;opacity:.7}

/* filter chip rows (category_filters.js wiring preserved) */
.category-filters{max-width:1280px;margin:24px auto 0;padding:0 32px}
.chip-row{display:flex;gap:8px;margin-bottom:10px}
.chip-row--scroll{overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.chip-row--scroll::-webkit-scrollbar{display:none}
.chip-row .chip{
  flex:none;display:inline-flex;align-items:center;
  font-size:12.5px;font-weight:700;letter-spacing:.05em;white-space:nowrap;
  border:1.5px solid var(--black);border-radius:999px;padding:8px 17px;
  background:transparent;color:inherit;cursor:pointer;
  transition:background .15s,color .15s,border-color .15s;
}
.chip-row .chip:hover{border-color:var(--orange-deep);color:var(--orange-deep)}
.chip-row .chip.chip-active{background:var(--black);border-color:var(--black);color:var(--cream)}
.chip-row .chip.chip-static{opacity:.55;cursor:default}

.category-sort-map-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:6px}
.sort-label{
  font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange-deep);
}
.category-sort{
  font-family:var(--text);font-size:13.5px;font-weight:500;color:var(--black);
  background:var(--cream);border:2px solid var(--black);border-radius:999px;padding:8px 14px;
}
.map-toggle-btn,
.boat-mode-toggle{
  font-family:var(--text);font-size:13px;font-weight:700;letter-spacing:.02em;
  border:2px solid var(--black);border-radius:999px;padding:8px 17px;
  background:transparent;color:inherit;cursor:pointer;
  transition:background .15s,color .15s,border-color .15s;
}
.map-toggle-btn:hover,
.boat-mode-toggle:hover{border-color:var(--orange-deep);color:var(--orange-deep)}
.map-toggle-btn[aria-expanded="true"],
.boat-mode-toggle--active,
.boat-mode-toggle[aria-pressed="true"]{background:var(--blue);border-color:var(--blue);color:var(--cream)}

/* collapsible map shell (scoped so it never fights map_view.css on /map).
   Show/hide is driven by the [hidden] attribute that map.js toggles — no
   class-based display rule here (the legacy .map-wrap--collapsed rule fought
   map.js, which toggles the class on <body>, the first [data-map-scope]). */
.category-page .map-wrap{max-width:1280px;margin:18px auto 0;padding:0 32px}
.category-page #map-container[hidden]{display:none}
.category-page #map-container{
  width:100%;height:400px;border:var(--d-border);border-radius:var(--d-radius);
  background:var(--cream);z-index:1;
}
@media(min-width:768px){.category-page #map-container{height:500px}}

/* sponsor slot shell (filled server-side elsewhere; empty stays invisible) */
.category-sponsor-slot{max-width:1280px;margin:0 auto;padding:0 32px}
.category-sponsor-slot-inner:empty{display:none}

/* card stream — hava_card partial restyled via CSS targeting only */
.category-stream{
  max-width:1280px;margin:26px auto 0;padding:0 32px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media(max-width:1080px){.category-stream{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.category-stream{grid-template-columns:1fr}}
.category-stream .hava-card,
.venue-events-list .hava-card{
  border:var(--d-border);border-radius:var(--d-radius);box-shadow:none;
  background:var(--cream);
  transition:transform .14s ease,box-shadow .14s ease;
}
.category-stream .hava-card:hover,
.venue-events-list .hava-card:hover{transform:translate(-3px,-3px);box-shadow:var(--d-shadow)}
.hava-card__sponsor{
  background:var(--orange);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;border-radius:999px;
}
.hava-card__title{font-family:var(--disp);font-weight:800;text-transform:uppercase;letter-spacing:.01em}
.hava-card__chip{border:1.5px solid var(--black);border-radius:999px;background:transparent;color:var(--black)}
.hava-card__chip--accent{background:var(--orange);border-color:var(--orange);color:var(--black)}

.category-editorial-footer{
  max-width:1280px;margin:40px auto 0;padding:22px 32px 0;
  border-top:3px solid var(--black);
  font-size:13.5px;font-weight:500;opacity:.75;
}
.category-editorial-footer a{color:var(--orange-deep);font-weight:700}

/* collection cards */
.collection-stream{
  max-width:1280px;margin:30px auto 0;padding:0 32px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media(max-width:1080px){.collection-stream{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.collection-stream{grid-template-columns:1fr}}
.collection-card{
  display:flex;flex-direction:column;background:var(--cream);
  border:var(--d-border);border-radius:var(--d-radius);overflow:hidden;
  transition:transform .14s ease,box-shadow .14s ease;
}
a.collection-card:hover{transform:translate(-3px,-3px);box-shadow:var(--d-shadow)}
.collection-card-media{height:150px;background-size:cover;background-position:center;border-bottom:var(--d-border)}
.collection-card-body{padding:18px 20px 20px}
.collection-card-name{
  font-family:var(--disp);font-weight:800;font-size:clamp(17px,1.8vw,21px);
  line-height:1.08;text-transform:uppercase;
}
.collection-card-where{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange-deep);margin-top:5px;
}
.collection-card-blurb{font-size:13.5px;font-weight:500;opacity:.8;margin-top:8px}
.collection-card-meta{font-size:12px;font-weight:500;opacity:.6;margin-top:8px}
.collection-eyebrow{display:none}/* superseded by the head eyebrow row */

/* ============================== /search =================================== */
.search-head{background:var(--black);color:var(--cream);padding:46px 0 50px}
.search-head h1{
  font-family:var(--disp);font-weight:800;font-size:clamp(38px,5.5vw,72px);
  line-height:.92;letter-spacing:-.025em;text-transform:uppercase;
}
.search-head h1 em{font-style:normal;color:var(--orange)}
.search-form{
  display:flex;background:var(--cream);border-radius:14px;overflow:hidden;
  max-width:620px;margin-top:24px;
}
.search-form input{
  flex:1;min-width:0;border:none;outline:none;background:transparent;
  font-family:var(--text);font-size:16px;color:var(--black);padding:15px 18px;
}
.search-form input::placeholder{color:#716552}
.search-form button{
  border:none;background:var(--orange-deep);color:var(--cream);cursor:pointer;
  padding:0 24px;font-family:var(--text);font-weight:700;font-size:14px;
  letter-spacing:.01em;
}
.search-form button:hover{background:var(--orange-deep)}
.search-ask-link{
  display:inline-block;margin-top:16px;
  font-size:13px;font-weight:700;letter-spacing:.02em;
  border-bottom:2px solid var(--orange);padding-bottom:2px;
}
.search-ask-link:hover{color:var(--peach)}
.search-main{padding-top:36px;padding-bottom:64px}
.search-summary{
  font-size:13px;font-weight:600;letter-spacing:0;opacity:.6;
  margin-bottom:22px;
}
.search-empty{margin:40px 0;font-size:16px;font-weight:500;max-width:52ch}
.search-empty a{color:var(--orange-deep);font-weight:700;border-bottom:2px solid var(--orange);padding-bottom:1px}
.search-section{margin-bottom:36px}
.search-section-title{
  font-family:var(--disp);font-weight:800;font-size:clamp(22px,2.6vw,32px);
  line-height:1;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:14px;
}
.search-list{
  background:var(--cream);border:var(--d-border);border-radius:var(--d-radius);overflow:hidden;
}
.search-row{padding:16px 24px;border-top:1.5px solid rgba(23,19,16,.14)}
.search-row:first-child{border-top:none}
.search-row:hover{background:var(--sand-light)}
.search-row-name{font-family:var(--disp);font-weight:700;font-size:17px;line-height:1.2;overflow-wrap:anywhere}
.search-row-name a:hover{color:var(--orange-deep)}
.search-row-subtype{
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  opacity:.55;margin-top:3px;
}
.search-row-phone{font-size:13.5px;font-weight:500;margin-top:3px}
.search-row-phone a{color:var(--orange-deep);font-weight:700}
.search-row-area{font-size:12.5px;font-weight:500;opacity:.65;margin-top:2px}
.search-row-meta{display:flex;gap:14px;font-size:13px;font-weight:500;opacity:.75;margin-top:3px}
.search-row-date{font-weight:700;color:var(--orange-deep)}
.search-ask-cta{margin-top:8px}
.search-ask-cta a{
  font-size:13.5px;font-weight:700;letter-spacing:.02em;
  border-bottom:2px solid currentColor;padding-bottom:2px;
}
.search-ask-cta a:hover{color:var(--orange-deep)}

/* ============================== /map chrome ===============================
   map_view.css keeps the load-bearing layout (#map-container fill, hidden
   toggle); this block reskins colors/typography and accounts for the sticky
   Desert header above the viewport-filling map. */
.map-page .map-page-main{height:calc(100dvh - 64px);min-height:480px}
.map-page .map-page-topbar{background:var(--sand-light);border-bottom:var(--d-border)}
.map-page .map-page-heading{align-items:center}
.map-page .map-title{
  font-family:var(--disp);font-weight:800;font-size:clamp(22px,3vw,34px);
  line-height:1;text-transform:uppercase;letter-spacing:-.01em;
}
.map-page .map-title em{font-style:normal;color:var(--orange-deep)}
.map-page .map-page-dateline{
  font-family:var(--text);font-size:11px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(23,19,16,.6);
}
.map-page .map-scope-label{
  font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange-deep);align-self:center;margin-right:4px;
}
.map-page .map-scope-tab{
  font-family:var(--text);font-size:12.5px;font-weight:700;letter-spacing:.05em;
  border:1.5px solid var(--black);border-radius:999px;padding:7px 15px;
  background:transparent;color:var(--black);
}
.map-page .map-scope-tab:hover{border-color:var(--orange-deep);color:var(--orange-deep)}
.map-page .map-scope-tab.is-active{background:var(--orange);border-color:var(--orange);color:var(--black)}
.map-page .map-scope-tab--category{font-weight:700;font-size:12px;color:rgba(23,19,16,.85)}
.map-page .map-scope-tab--category.is-active{color:var(--black)}
.map-page .map-page-container{background:var(--sand)}

/* ============================== responsive ================================ */
@media(max-width:1080px){
  .cat-head .cathead{grid-template-columns:1fr;align-items:start}
  .cat-head .giant,.cat-head .giant small{text-align:left}
}
@media(max-width:700px){
  .wrap{padding-left:20px;padding-right:20px}
  .cat-head .cathead{padding-top:32px;padding-bottom:38px}
  .catbar .sortnote{display:none}
  .hava-search-bar,.category-filters,.category-sponsor-slot,.category-stream,
  .collection-stream,.category-editorial-footer,
  .category-page .map-wrap{padding-left:20px;padding-right:20px}
  .pager{justify-content:center}
}

/* B.2 department landing — child-leaf cards (counts + links). */
.dept-leaf-grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  margin:24px 0 40px;
}
.dept-leaf-card{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  padding:16px 18px;background:var(--cream);
  border:var(--d-border);border-radius:var(--d-radius);
  text-decoration:none;color:var(--text);transition:.12s;
}
.dept-leaf-card:hover{border:var(--d-border-thick);box-shadow:var(--d-shadow);transform:translateY(-1px)}
.dept-leaf-name{font-weight:600;font-size:1.02rem}
.dept-leaf-count{color:var(--blue-deep);font-size:.85rem;white-space:nowrap}

/* G Tier-3 category-claim slot on category/leaf pages (sell-side funnel). */
.cat-claim{display:flex;align-items:center;justify-content:space-between;gap:18px;
  flex-wrap:wrap;margin:28px 0 8px;padding:18px 22px;
  background:var(--sand-light, var(--sand));border:var(--d-border-thick);
  border-radius:var(--d-radius-lg)}
.cat-claim-body{display:flex;flex-direction:column;gap:4px;max-width:46rem}
.cat-claim-body .d-tag{align-self:flex-start}
.cat-claim-body h2{font-size:1.25rem;margin:2px 0;color:var(--text)}
.cat-claim-body p{font-size:.92rem;color:var(--text);opacity:.85;margin:0}
.cat-claim-cta{flex:0 0 auto;align-self:center;padding:11px 20px;
  background:var(--orange);color:var(--black);border-radius:999px;
  font-weight:700;text-decoration:none;white-space:nowrap;transition:.12s}
.cat-claim-cta:hover{filter:brightness(1.06);transform:translateY(-1px)}
@media(prefers-reduced-motion:reduce){.cat-claim-cta:hover{transform:none}}
