/* Strata Match — per-city directory page (/companies/by-city/[city]). Styles
   ported from the handoff "City.html" ?city= view (reskin tokens). The 3-up
   .city-stats cards and the dark masthead/topbar are intentionally OMITTED —
   the page opens straight into a light breadcrumb + hero for breathing room. */
  .crumb{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-subtle);
    display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin-bottom:26px;}
  .crumb a{color:var(--teal-700);text-decoration:none;} .crumb a:hover{text-decoration:underline;}
  .crumb span{opacity:.5;} .crumb em{font-style:normal;color:var(--fg);}

  .city-hero{max-width:760px;}
  .city-hero h1{font-family:var(--font-display);font-size:clamp(38px,5.4vw,68px);line-height:1.02;letter-spacing:-0.02em;color:var(--ink);margin-top:10px;text-wrap:balance;}
  .city-lead{margin-top:20px;font-size:20px;line-height:1.6;color:var(--fg-muted);} .city-lead strong{color:var(--ink);font-weight:var(--w-body-b);}
  .city-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;}

  /* firm list */
  .city-list-sec{margin-top:56px;}
  .list-head{display:flex;justify-content:space-between;align-items:baseline;gap:18px;flex-wrap:wrap;border-bottom:1px solid var(--border-strong);padding-bottom:14px;}
  .list-head h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);color:var(--ink);}
  .list-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-subtle);}
  .city-list{margin-top:12px;}
  .reg-row{display:grid;grid-template-columns:minmax(320px,1.35fr) minmax(240px,.9fr) minmax(230px,.75fr) auto;gap:24px;align-items:center;
    margin:12px 0;padding:22px 24px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-top:3px solid var(--teal-500);
    color:inherit;box-shadow:0 10px 30px rgba(7,23,43,.035);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);}
  .reg-row:hover{border-color:var(--teal-300);box-shadow:0 16px 36px rgba(7,23,43,.075);transform:translateY(-1px);}
  .reg-main{display:grid;grid-template-columns:56px 1fr;gap:18px;align-items:center;min-width:0;color:inherit;text-decoration:none;}
  .reg-main:focus-visible,.reg-profile:focus-visible{outline:2px solid var(--teal-600);outline-offset:3px;}
  .mono-tile{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--teal-50);
    color:var(--teal-700);border:1px solid var(--teal-100);font-family:var(--font-mono);font-weight:600;font-size:15px;letter-spacing:.01em;}
  .reg-firm{min-width:0;}
  .reg-firm-name{display:block;margin:0;font-family:var(--font-display);font-size:clamp(22px,2.1vw,30px);line-height:1.05;color:var(--fg);}
  .reg-main:hover .reg-firm-name{color:var(--teal-700);}
  .lic{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--fg-subtle);text-transform:uppercase;margin-top:5px;}
  .col-svc{min-width:0;align-self:start;}
  .reg-badges{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;min-height:28px;margin-bottom:12px;}
  .badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;box-sizing:border-box;
    font-family:var(--font-mono);font-size:10px;font-weight:600;line-height:1;letter-spacing:.1em;padding:3px 9px;
    border:1px solid var(--teal-200);color:var(--teal-700);background:var(--teal-50);}
  .badge.spabc{border-color:var(--amber-200);color:var(--amber-700);background:var(--amber-50);}
  .badge.pama{border-color:var(--navy-200);color:var(--navy-700);background:var(--navy-50);}
  .svc{display:block;font-family:var(--font-mono);font-size:11px;line-height:1.5;letter-spacing:.04em;color:var(--fg-muted);text-transform:uppercase;}
  .reg-evidence{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:wrap;min-width:0;}
  .status{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
  .status .d{width:7px;height:7px;border-radius:999px;}
  .taking{color:var(--success);} .taking .d{background:var(--success);}
  .wait{color:var(--fg-subtle);} .wait .d{background:var(--fg-subtle);}
  .reg-profile{justify-self:end;display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:0 16px;
    border:1px solid var(--border-strong);color:var(--teal-800);background:var(--paper);text-decoration:none;
    font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;}
  .reg-profile:hover{background:var(--teal-50);border-color:var(--teal-300);}
  .list-foot{margin-top:22px;font-size:14.5px;line-height:1.6;color:var(--fg-subtle);font-style:italic;max-width:70ch;}
  .list-foot a{color:var(--accent-text);}

  /* council-check band */
  .check-band{margin-top:64px;background:var(--surface-edit);border:1px solid var(--border);border-left:3px solid var(--terracotta);}
  .check-inner{position:relative;padding:40px 44px;}
  .check-eyebrow{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-text);}
  .check-inner h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);color:var(--ink);margin-top:8px;}
  .check-list{list-style:none;padding:0;margin:26px 0 0;display:grid;grid-template-columns:1fr 1fr 1fr;gap:26px;}
  .check-list li{display:flex;gap:14px;align-items:flex-start;font-size:15.5px;line-height:1.55;color:var(--fg);}
  .check-list .ck{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent-text);border:1px solid var(--t-200);padding:5px 8px;flex:none;}
  .check-list strong{font-weight:var(--w-body-b);color:var(--ink);} .check-list a{color:var(--accent-text);}

  /* faq */
  .city-faq{margin-top:64px;} .faq-wrap{max-width:820px;} .city-faq h2{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);color:var(--ink);}
  .faqlist{margin-top:22px;}
  .qa{border-bottom:1px solid var(--hairline);}
  .qa summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:20px;align-items:flex-start;
    padding:20px 0;font-family:var(--font-display);font-size:clamp(19px,2vw,23px);line-height:1.28;color:var(--ink);}
  .qa summary::-webkit-details-marker{display:none;}
  .qa .tw{flex:none;width:30px;height:30px;border:1px solid var(--teal-300);border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--teal-700);transition:transform var(--dur-fast),background var(--dur-fast),color var(--dur-fast);}
  .qa[open] .tw{transform:rotate(45deg);background:var(--teal-600);color:#fff;border-color:var(--teal-600);}
  .qa .a{padding:0 0 22px;max-width:64ch;} .qa .a p{font-size:16.5px;line-height:1.62;color:var(--fg-muted);} .qa .a a{color:var(--accent-text);}

  /* nearby */
  .near-sec{margin-top:56px;}
  .city-near{border-top:1px solid var(--border);padding-top:28px;}
  .near-h{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-700);}
  .near-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;align-items:center;}
  /* min-height 44px: WCAG/HIG touch-target minimum (was 42px). */
  .near-chips a{font-family:var(--font-mono);font-size:13px;color:var(--navy-700);text-decoration:none;background:var(--bg-elevated);
    border:1px solid var(--border-strong);padding:9px 14px;min-height:44px;box-sizing:border-box;display:inline-flex;align-items:center;gap:8px;transition:all var(--dur-fast);}
  .near-chips a:hover{border-color:var(--teal-500);color:var(--teal-700);background:var(--teal-50);}
  .near-chips .nc{font-size:11px;color:var(--fg-subtle);}
  .near-chips a:hover .nc{color:var(--teal-600);}
  .near-all{color:var(--accent-text)!important;border-color:transparent!important;background:transparent!important;font-weight:600;letter-spacing:.04em;}

  @media(max-width:1200px){
    .reg-row{grid-template-columns:1fr;gap:16px;margin:12px 0;padding:18px;align-items:start;}
    .reg-main{grid-template-columns:48px 1fr;gap:14px;}
    .reg-row:hover{transform:none;}
    .col-svc{padding-top:2px;}
    .reg-evidence{padding-top:2px;}
    .reg-profile{justify-self:stretch;justify-content:center;}
    .mono-tile{width:48px;height:48px;font-size:13px;}
    .check-list{grid-template-columns:1fr;gap:18px;}
  }
