/* directory.css - service directory (filters + collapsible results). */
.skip-link { position: absolute; left: 1rem; top: -5rem; z-index: 20; padding: .75rem 1rem; background: var(--primary); color: #fff; border-radius: 999px; text-decoration: none; }
.skip-link:focus { top: 1rem; }

.directory-page { display: grid; gap: 24px; }
.directory-hero { padding-top: 40px; text-align: center; }
.directory-hero h1 { max-width: 820px; margin: 8px auto; }
.directory-layout { display: grid; gap: 22px; }

/* panels */
.panel, .results-panel, .service-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.panel, .results-panel { padding: 22px; }
.panel-heading { display: flex; justify-content: space-between; align-items: start; gap: 18px; margin-bottom: 18px; }
.panel-heading h2, .empty-state h2 { margin: 0; }
.title-with-help { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.title-with-help p, .panel-intro, .result-count, .service-meta, .service-area-meta, .service-type-meta { color: var(--muted); margin: 0; }
.panel-intro { margin-top: 6px; }
.privacy-note { max-width: 780px; font-size: .95rem; }
.result-count { font-weight: 700; }

/* filters */
.filter-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px,100%), 1fr)); gap: 14px; }
.filter-grid label { font-weight: 600; color: var(--text); }
.filter-grid label span, legend { display: block; margin-bottom: 6px; color: var(--muted); font-size: .85rem; font-weight: 600; }
.checkbox-filter { margin: 0; padding: 0; border: 0; }
.filter-choice-group { display: grid; gap: 12px; margin-top: 14px; padding: 14px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--neutral3); }
.checkbox-filter-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(150px,100%), 1fr)); gap: 8px; }
.filter-check { display: flex; align-items: center; gap: 8px; min-height: 44px; margin: 0; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: #fff; font-size: .9rem; font-weight: 600; cursor: pointer; }
.filter-check input { width: 1rem; height: 1rem; flex: 0 0 auto; accent-color: var(--primary); }
.filter-check.is-selected, .filter-check:has(input:checked) { border-color: var(--primary); background: var(--pale-aqua); }
.filter-check-wide { justify-self: start; }

/* Search input + selects use the shared field styles in main.css; the filter
   checkboxes keep their own sizing via .filter-check input above. */

/* results: areas -> types -> cards */
.service-area-list { display: grid; gap: 14px; }
.service-area-detail, .service-type-detail { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; overflow: hidden; }
.service-area-detail summary, .service-type-detail summary { list-style: none; cursor: pointer; padding: 16px 18px; }
.service-area-detail summary::-webkit-details-marker, .service-type-detail summary::-webkit-details-marker { display: none; }
.service-area-summary, .service-type-summary { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.service-area-title { font-family: var(--serif); font-size: 1.1rem; font-weight: 700; }
.service-type-title { font-family: var(--serif); color: var(--primary-dark); font-weight: 700; }
.service-area-meta, .service-type-meta { margin-top: 4px; font-size: .9rem; }
.service-area-inner, .service-type-inner { display: grid; gap: 12px; padding: 0 18px 16px; }

.service-card { padding: 1rem; }
.card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.service-card h2 { margin: 0; color: var(--primary-dark); font-size: 1.2rem; text-align: left; }
.service-meta, .contact-list, .detail-list { display: flex; flex-wrap: wrap; gap: .45rem .7rem; }
.service-meta { margin-top: .45rem; font-size: .9rem; }
.service-badge { display: inline-flex; align-items: center; padding: .2rem .55rem; border-radius: 999px; background: #fff4df; color: #8a5a11; font-size: .78rem; font-weight: 700; }
.description { margin: .85rem 0; color: var(--text); }
.detail-list { margin-top: .8rem; }
.detail { flex: 1 1 14rem; min-width: 0; padding: .75rem; border-left: 3px solid var(--primary); background: var(--neutral3); border-radius: 0 8px 8px 0; }
.detail strong { display: block; margin-bottom: .2rem; color: var(--primary-dark); font-size: .78rem; text-transform: uppercase; }
.detail span, .detail a, .contact-list a, .contact-list span { overflow-wrap: anywhere; }
.contact-list { margin-top: .9rem; padding-top: .85rem; border-top: 1px solid var(--line); }

.empty-state { padding: 2rem; text-align: center; }
.empty-state p { margin: 0; color: var(--muted); }

@media (max-width: 720px) {
  .card-top, .panel-heading, .service-area-summary, .service-type-summary { display: grid; }
  .checkbox-filter-options { grid-template-columns: 1fr; }
  .detail { flex-basis: 100%; }
}
