@import "/assets/fonts.css";

:root {
  color-scheme: light;
  /* brand */
  --indigo:#3858c8; --indigo-strong:#2a44a0; --indigo-bg:#eaeefb;
  /* ink / neutrals */
  --ink:#1e2a4a; --ink-2:#3a4566; --muted:#646e85; --faint:#6b6f7d;
  --line:#e3e7ef; --line-soft:#eef1f6;
  --canvas:#f7f8fa; --panel:#fcfcfe; --surface:#ffffff;
  /* signal status scale (CVD-safe; always paired with text/icon) */
  --good:#0e8a7a; --good-bg:#e3f4f1;
  --mod:#9a5413;  --mod-bg:#fbeede;
  --long:#c4453a; --long-bg:#fbe9e7;
  --amber:#e8943a;
  /* legacy aliases kept so nothing breaks mid-refactor */
  --accent:var(--indigo); --accent-strong:var(--indigo-strong);
  --soft:var(--indigo-bg); --warning:var(--mod); --danger:var(--long);
  /* type */
  --font-sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono:"IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
  /* radii / shadow / motion */
  --r-sm:8px; --r-md:11px; --r-lg:14px;
  --shadow-1:0 1px 3px rgba(20,30,55,.06), 0 6px 16px rgba(20,30,55,.05);
  --shadow-2:0 4px 14px rgba(30,42,74,.07);
  --dur:.16s; --ease:cubic-bezier(.2,.6,.2,1);
  --page-max:1280px;
}

:root[data-theme="dark"], :root.theme-dark {
  color-scheme: dark;
  --indigo:#8aa6f5; --indigo-strong:#aac0ff; --indigo-bg:#1c2748;
  --ink:#eef2fb; --ink-2:#c4cce0; --muted:#9aa6c2; --faint:#6b779a;
  --line:#2a3556; --line-soft:#222c49;
  --canvas:#0e1426; --panel:#141d33; --surface:#18213a;
  --good:#3fc7b4; --good-bg:#10342f;
  --mod:#e2a45c;  --mod-bg:#3a2c17;
  --long:#f08a80; --long-bg:#3a2120;
  --amber:#f0a455;
  --shadow-1:0 1px 3px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.35);
  --shadow-2:0 4px 16px rgba(0,0,0,.45);
}

* { box-sizing: border-box; }

body {
  margin:0; min-width:320px;
  color:var(--ink); background:var(--canvas);
  font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;
}

.mono { font-family:var(--font-mono); font-variant-numeric:tabular-nums; }

button, input, select { font:inherit; }

button {
  border:1px solid var(--line); border-radius:var(--r-sm);
  padding:.58rem .78rem; color:var(--ink); background:var(--surface);
  cursor:pointer; transition:border-color var(--dur) var(--ease), color var(--dur) var(--ease), background var(--dur) var(--ease), transform .1s var(--ease);
}
button:hover:not(:disabled), button.active {
  border-color:var(--indigo); color:var(--indigo-strong); background:var(--indigo-bg);
}
button:active:not(:disabled) { transform:scale(.98); }
button:disabled { cursor:not-allowed; opacity:1; color:var(--ink-2); background:var(--line-soft); }
/* buttons that contain a leading icon: align icon + text */
button:has(> .icon) { display:inline-flex; align-items:center; gap:.4rem; }
button > .icon { flex:none; }

:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline:none; border-color:var(--indigo);
  box-shadow:0 0 0 3px var(--indigo-bg);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important;
  }
  .skeleton .sk-line, .skeleton .sk-chips {
    animation:none !important;
    background:var(--line);
  }
}

.skip-link {
  position:absolute; left:1rem; top:.75rem; z-index:100;
  padding:.55rem .75rem; border-radius:var(--r-sm);
  color:#fff; background:var(--indigo); text-decoration:none; font-weight:700;
  transform:translateY(-160%);
  transition:transform var(--dur) var(--ease);
}
.skip-link:focus-visible { transform:translateY(0); outline:none; box-shadow:0 0 0 3px var(--indigo-bg); }
main:focus { outline:none; }
main[hidden] { display:none; }
main {
  width:min(100%, var(--page-max)); margin-inline:auto;
}

/* ---------- header ---------- */
.app-header {
  display:flex; align-items:center; justify-content:space-between; gap:1.75rem;
  width:min(100%, var(--page-max)); margin-inline:auto;
  padding:1.15rem 1.75rem; border-bottom:1px solid var(--line); background:var(--surface);
}
.app-header[hidden] { display:none; }
.brand { display:flex; align-items:center; gap:.8rem; text-decoration:none; color:inherit; }
.brand-mark { display:inline-flex; }
.brand-text { display:grid; gap:.15rem; }
.brand-name { font-weight:700; font-size:1.15rem; letter-spacing:-.015em; color:var(--ink); margin:0; }
.eyebrow { color:var(--indigo); font-size:.72rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase; margin:0; }
.header-controls { display:flex; align-items:flex-end; gap:.7rem; flex-wrap:wrap; justify-content:flex-end; }
.role-switcher { display:flex; flex-wrap:wrap; gap:.4rem; }
.role-button { display:inline-flex; align-items:center; gap:.35rem; font-size:.8rem; font-weight:600; padding:.45rem .7rem; }
/* full-blue primary button (matches Save snapshot) */
.btn-primary { display:inline-flex; align-items:center; gap:.4rem; font-weight:600; font-size:.82rem;
  padding:.5rem .9rem; min-height:38px; border:none; border-radius:var(--r-sm);
  background:var(--indigo); color:#fff; cursor:pointer; transition:background var(--dur) var(--ease), transform .1s var(--ease); }
.btn-primary:hover:not(:disabled) { background:var(--indigo-strong); color:#fff; }
.btn-primary:active:not(:disabled) { transform:scale(.98); }
.btn-primary:disabled { background:var(--line-soft); color:var(--ink-2); cursor:not-allowed; }
/* icon-only animated sun/moon theme toggle (no button chrome) */
.theme-toggle { display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px;
  padding:0; border:none; background:none; color:var(--muted); cursor:pointer; border-radius:50%;
  transition:color var(--dur) var(--ease), background var(--dur) var(--ease); }
.theme-toggle:hover { color:var(--indigo); background:var(--indigo-bg); }
.theme-toggle .icon { transition:transform .4s var(--ease), opacity .25s var(--ease); }
.theme-toggle .sun { color:var(--amber); }
.theme-toggle .moon { color:var(--indigo); }
.field { display:grid; gap:.3rem; }
.session-panel { display:flex; align-items:center; gap:.7rem; }
.session-panel span { color:var(--muted); font-size:.88rem; font-weight:600; }
.session-panel[hidden], .role-switcher[hidden] { display:none; }

/* ---------- guardrail ---------- */
.guardrail-band { display:flex; flex-wrap:wrap; gap:.5rem 1.5rem; padding:.7rem 1.75rem;
  background:var(--panel); border-bottom:1px solid var(--line); }
.guardrail-band span { display:inline-flex; align-items:center; gap:.45rem; font-size:.8rem; color:var(--ink-2); font-weight:500; }
.guardrail-band span::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--indigo); opacity:.5; }

/* ---------- filter bar ---------- */
.filter-bar { display:grid; gap:.9rem;
  padding:1.15rem 1.75rem 1rem; border-bottom:1px solid var(--line); background:var(--surface); }
.filter-primary { display:grid; grid-template-columns:minmax(260px,2fr) minmax(150px,.9fr) minmax(145px,.75fr) minmax(220px,1fr) auto;
  align-items:start; gap:1rem; }
.field-label { display:flex; align-items:center; gap:.3rem; min-height:1rem; margin-bottom:.05rem;
  font-size:.72rem; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; }
.filter-bar .field { display:grid; gap:.35rem; align-content:start; min-width:150px; }
/* Checkbox filter ("Accepting referrals only"): a toggle, not a labelled field. It has no
   field-label row, so bottom-align it within the flex group (align-self) to sit on the same
   row as the neighbouring inputs rather than floating up at label height. The pill-style box
   (border + height matching inputs) makes it read as a control. */
.filter-bar .field-check { min-width:0; align-self:flex-end; }
.filter-actions { display:flex; align-items:flex-end; gap:.5rem; min-height:calc(1rem + .05rem + .35rem + 40px); }
.filter-reset, .filter-toggle { height:40px; white-space:nowrap; }
.filter-reset[hidden] { display:none; }
.filter-toggle { display:inline-flex; align-items:center; gap:.4rem; font-weight:700; }
.filter-toggle[aria-expanded="true"] { border-color:var(--indigo); background:var(--indigo-bg); color:var(--indigo-strong); }
.filter-count { display:inline-grid; min-width:1.25rem; height:1.25rem; place-items:center; padding:0 .32rem;
  border-radius:999px; background:var(--indigo); color:#fff; font-size:.72rem; line-height:1; }
.checkbox-row { display:inline-flex; align-items:center; gap:.5rem; height:40px; padding:0 .8rem;
  border:1px solid var(--line); border-radius:var(--r-sm); background:var(--surface);
  font-size:.82rem; font-weight:600; color:var(--ink-2); white-space:nowrap; cursor:pointer;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease); }
.checkbox-row:hover { border-color:var(--indigo); }
.checkbox-row:has(input:checked) { border-color:var(--indigo); background:var(--indigo-bg); color:var(--ink); }
.checkbox-row input { width:1rem; height:1rem; margin:0; accent-color:var(--indigo); cursor:pointer; }
.search-wrap { position:relative; display:flex; align-items:center; }
.search-icon { position:absolute; left:.65rem; color:var(--faint); pointer-events:none; }
.search-wrap input { padding-left:2rem; }
.filter-chip-list { display:flex; flex-wrap:wrap; gap:.45rem; min-height:1.65rem; }
.filter-chip-list[hidden] { display:none; }
.filter-chip { display:inline-flex; align-items:center; gap:.35rem; height:1.65rem; padding:0 .55rem;
  border:1px solid var(--line); border-radius:999px; background:var(--panel); color:var(--ink-2);
  font-size:.76rem; font-weight:700; }
.chip-remove { display:inline-grid; place-items:center; width:1rem; height:1rem; padding:0; border:none;
  border-radius:50%; background:var(--line-soft); color:var(--muted); font-size:.7rem; line-height:1; }
.chip-remove:hover, .chip-remove:focus-visible { color:#fff; background:var(--indigo); box-shadow:none; }
.advanced-filters { display:grid; grid-template-columns:1.2fr .85fr .85fr; gap:1.2rem;
  padding-top:1rem; border-top:1px solid var(--line); }
.advanced-filters[hidden] { display:none; }
.advanced-filter-section { display:grid; align-content:start; gap:.65rem; }
.advanced-filter-title { color:var(--ink); font-size:.78rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }
.advanced-filter-fields { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:.8rem; }
/* equal control height across inputs + selects */
input, select { width:100%; height:40px; border:1px solid var(--line); border-radius:var(--r-sm);
  padding:.5rem .65rem; color:var(--ink); background:var(--surface);
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
textarea { padding:.5rem .65rem; }

/* ---------- workspace (master-detail) ---------- */
.workspace { display:grid; grid-template-columns:minmax(340px,420px) 1fr; min-height:calc(100vh - 240px); }
/* Left panel fills the viewport below the header/filter chrome (~240px, matching .workspace);
   the heading stays pinned and only the result list scrolls inside it. */
.results-panel { padding:1.25rem 1.25rem; border-right:1px solid var(--line); background:var(--panel);
  max-height:calc(100vh - 240px); display:flex; flex-direction:column; overflow:hidden; }
.profile-panel { padding:1.75rem 2rem; background:var(--surface); overflow:auto; outline:none; }
.section-heading { display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:1.1rem; }
.section-heading h2 { margin:0; font-size:.82rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); }
.results-summary { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; justify-content:flex-end; }
.results-count { font-size:.8rem; color:var(--faint); }
.sort-indicator { font-size:.76rem; font-weight:600; color:var(--muted); }

/* ---------- result cards ---------- */
/* The list fills the panel's remaining height (viewport-bound) and scrolls on its own, so the
   page itself doesn't grow and the match-count heading stays in view. */
.result-list { display:grid; gap:.7rem; flex:1 1 auto; min-height:0; overflow-y:auto; padding-right:.35rem; overscroll-behavior:contain; }
.result-list > [role="listitem"] { display:block; }
.result-card { display:grid; gap:.45rem; width:100%; text-align:left; padding:1.05rem 1.1rem;
  border:1px solid var(--line); border-radius:var(--r-md); background:var(--surface); position:relative;
  /* Long lists (the default Calgary view is ~1,600 cards): skip layout/paint for off-screen
     cards so scrolling stays smooth. contain-intrinsic-size reserves each card's height so the
     scrollbar is stable. */
  content-visibility:auto; contain-intrinsic-size:auto 132px;
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.result-card:hover { border-color:var(--indigo); box-shadow:var(--shadow-2); }
.result-card.selected { border-color:var(--indigo); background:var(--indigo-bg); }
.result-card.selected::before { content:""; position:absolute; left:0; top:14px; bottom:14px; width:3px; border-radius:0 3px 3px 0; background:var(--indigo); }
.result-title { font-weight:700; font-size:1rem; letter-spacing:-.01em; color:var(--ink); display:flex; align-items:center; gap:.4rem; }
.result-sub { font-size:.85rem; color:var(--muted); }
.result-meta { display:flex; flex-direction:column; gap:.2rem; margin:.15rem 0 .1rem; }
.result-meta-row { display:flex; align-items:flex-start; gap:.4rem; font-size:.8rem; color:var(--muted); line-height:1.4; }
.result-meta-row svg { flex:0 0 auto; margin-top:.1rem; color:var(--faint); }

/* ---------- chips ---------- */
.chips { display:flex; flex-wrap:wrap; gap:.45rem; margin-top:.3rem; }
.chip { font-size:.72rem; font-weight:600; padding:.18rem .55rem; border-radius:20px; display:inline-flex; align-items:center; gap:.25rem; }
.chip .mono { font-size:.72rem; }
.chip .icon { flex:none; }
.icon { display:inline-block; vertical-align:middle; }
.chip-rate { background:var(--indigo-bg); color:var(--indigo-strong); }
.chip-good { background:var(--good-bg); color:var(--good); }
.chip-mod  { background:var(--mod-bg);  color:var(--mod); }
.chip-long { background:var(--long-bg); color:var(--long); }
.chip-neutral { background:var(--line-soft); color:var(--muted); }
.caution { display:inline-grid; width:1.05rem; height:1.05rem; place-items:center; border-radius:50%;
  color:#fff; background:var(--mod); font-size:.7rem; font-weight:700; }

/* ---------- skeleton ---------- */
.skeleton { pointer-events:none; }
.skeleton .sk-line, .skeleton .sk-chips { display:block; border-radius:6px;
  background:linear-gradient(90deg,var(--line-soft),var(--line),var(--line-soft));
  background-size:200% 100%; animation:shimmer 1.2s linear infinite; }
.skeleton .sk-line { height:.7rem; margin-bottom:.45rem; }
.skeleton .w60 { width:60%; } .skeleton .w40 { width:40%; }
.skeleton .sk-chips { height:1rem; width:80%; margin-top:.5rem; }
@keyframes shimmer { from { background-position:200% 0; } to { background-position:-200% 0; } }

/* ---------- profile ---------- */
.profile-header { display:flex; align-items:flex-start; justify-content:space-between; gap:1.2rem; }
.profile-header h2, .profile-header h3 { margin:.2rem 0 .25rem; font-size:1.6rem; font-weight:800; letter-spacing:-.02em; }
.profile-header .eyebrow { color:var(--indigo); }
.profile-header p { color:var(--muted); margin:0; max-width:48ch; }
.source-box { display:grid; gap:.15rem; padding:.8rem .9rem; min-width:200px; border:1px solid var(--line);
  border-radius:var(--r-md); background:var(--panel); }
.source-box strong { font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); }
.source-box span { font-size:.9rem; color:var(--ink); }
.source-box small, .source-box time { color:var(--faint); font-size:.8rem; }
.warning, .access-message { padding:.75rem .85rem; border:1px solid color-mix(in srgb, var(--mod) 45%, var(--line));
  border-radius:var(--r-md); color:var(--mod); background:var(--mod-bg); animation:noticeIn var(--dur) var(--ease) both; }
.form-message.error, .access-message.error { color:var(--long); background:var(--long-bg); border-color:color-mix(in srgb, var(--long) 45%, var(--line)); }
@keyframes noticeIn { from { opacity:0; transform:translateY(-3px); } to { opacity:1; transform:none; } }

/* ---------- metrics ---------- */
.metrics-grid { display:grid; grid-template-columns:repeat(3,minmax(160px,1fr)); gap:.8rem; margin:1.6rem 0; }
.ratings-withheld { display:flex; align-items:flex-start; gap:.4rem; margin:0 0 1.2rem;
  font-size:.82rem; color:var(--muted); line-height:1.45; }
.ratings-withheld svg { flex:0 0 auto; margin-top:.1rem; color:var(--faint); }
/* icon column (full card height) on the left, content on the right */
.metric { display:flex; align-items:stretch; gap:.85rem; padding:.9rem 1rem; border:1px solid var(--line);
  border-radius:var(--r-md); background:var(--surface); min-height:96px;
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.metric:hover { border-color:color-mix(in srgb, var(--indigo) 35%, var(--line)); box-shadow:var(--shadow-1); }
.metric-icon { flex:none; display:flex; align-items:center; justify-content:center; width:2.6rem; align-self:stretch;
  border-radius:var(--r-sm); background:var(--indigo-bg); color:var(--indigo); }
.metric-body { display:grid; gap:.25rem; align-content:start; min-width:0; }
.metric .mlabel { font-size:.72rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }
.metric .mval { font-size:1.35rem; font-weight:600; letter-spacing:-.02em; color:var(--ink); }
.metric .mval-text { font-size:1.05rem; }
.metric .mval-of { color:var(--faint); font-weight:500; font-size:.7em; }
.metric .mval-empty { font-size:1rem; font-weight:600; color:var(--faint); }
.metric .mfoot { color:var(--faint); font-size:.75rem; }
/* read-only star display in rating metric cards (cohesive with the snapshot form stars) */
.star-row-display { display:inline-flex; gap:.1rem; margin-top:.1rem; }
.star-display { position:relative; display:inline-flex; width:16px; height:16px; line-height:0; }
.star-display .star-bg { color:var(--line); }
.star-display .star-fg { position:absolute; left:0; top:0; overflow:hidden; color:var(--amber); white-space:nowrap; }
.star-display .icon { display:block; }
.status-row { display:inline-flex; align-items:center; gap:.4rem; font-size:.8rem; font-weight:600; }
.status-row .dot { width:9px; height:9px; border-radius:50%; }
.status-good .dot { background:var(--good); } .status-good { color:var(--good); }
.status-mod .dot  { background:var(--mod); }  .status-mod  { color:var(--mod); }
.status-long .dot { background:var(--long); } .status-long { color:var(--long); }
.status-neutral .dot { background:var(--faint); } .status-neutral { color:var(--muted); }

/* ---------- location · referral (2 columns) ---------- */
.location-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.75rem; align-items:start; margin-top:.4rem; }
.location-col { display:flex; flex-direction:column; min-width:0; }
.location-col h3 { font-size:1rem; font-weight:700; letter-spacing:-.01em; margin:0 0 .7rem; }
.referral-actions { margin-top:auto; padding-top:1rem; display:flex; justify-content:flex-end; }
.btn-small { display:inline-flex; align-items:center; gap:.35rem; font-size:.78rem; font-weight:600; min-height:0;
  padding:.4rem .65rem; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--surface); color:var(--muted); cursor:pointer; }
.btn-small:hover:not(:disabled) { border-color:var(--indigo); color:var(--indigo); background:var(--indigo-bg); }
.location-address { margin:0 0 .8rem; line-height:1.5; }
.location-zone { margin:0 0 .8rem; font-size:.85rem; color:var(--muted); }
.addr-desc { color:var(--muted); font-size:.85rem; }
.contact-list { display:grid; gap:.5rem; }
.contact-row { display:flex; gap:.6rem; align-items:baseline; }
.contact-label { flex:0 0 5rem; font-size:.72rem; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.contact-value { color:var(--ink); }
.contact-value a, .referral-note a { color:var(--indigo); text-decoration:none; }
.contact-value a:hover, .referral-note a:hover { text-decoration:underline; }
.referral-note { margin-top:.9rem; }
.referral-note .contact-label { display:block; margin-bottom:.25rem; }
.referral-note p { margin:0; color:var(--ink-2); line-height:1.5; max-width:52ch; }

/* directions link */
.location-directions { margin-top:.9rem; }
.map-link { display:inline-flex; align-items:center; gap:.3rem; font-weight:600; color:var(--indigo); text-decoration:none; }
.map-link:hover { text-decoration:underline; }

/* location cards with badges */
.subtitle-interest { color:var(--muted); margin:.1rem 0 0; font-size:.95rem; }
.ard-link { font-size:.8rem; font-weight:600; margin-left:.5rem; vertical-align:middle; }
.loc-list { display:flex; flex-direction:column; gap:.7rem; }
.loc-card { border:1px solid var(--line); border-radius:12px; padding:.85rem 1rem; }
.loc-top { display:flex; justify-content:space-between; align-items:flex-start; gap:.75rem; }
.loc-head { min-width:0; }
.loc-name { font-weight:700; color:var(--ink); }
.loc-addr { margin:.3rem 0 0; color:var(--ink-2); font-size:.85rem; line-height:1.5; }
.loc-meta { margin:.4rem 0 0; color:var(--muted); font-size:.78rem; }
.loc-notes { margin:.4rem 0 0; color:var(--ink-2); font-size:.82rem; font-style:italic; }
.loc-foot { display:flex; align-items:center; justify-content:space-between; gap:.6rem; flex-wrap:wrap; margin-top:.6rem; }
.loc-distance { display:inline-flex; align-items:center; gap:.3rem; font-size:.82rem; font-weight:600; color:var(--ink-2); }
.loc-directions { font-size:.82rem; }
.badge { font-size:.7rem; font-weight:700; padding:.25rem .55rem; border-radius:999px; white-space:nowrap; }
.badge-yes { background:#dcfce7; color:#166534; }
.badge-no { background:#fee2e2; color:#991b1b; }
.badge-loa { background:#fef3c7; color:#92400e; }
.badge-unknown { background:var(--line); color:var(--muted); }
.profile-aside { margin-top:.9rem; }
.profile-aside .contact-label { display:block; margin-bottom:.25rem; }
.profile-aside p { margin:0; color:var(--ink-2); line-height:1.5; max-width:52ch; }

.sr-label { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---------- filter-bar location control ---------- */
.location-field { min-width:220px; }
.location-control { display:flex; align-items:center; }
.loc-autocomplete { position:relative; flex:1 1 auto; min-width:0; }
.loc-autocomplete input { width:100%; padding-right:2.3rem; }
/* "locate me" arrow docked at the right end of the address field (maps-app pattern) */
.loc-locate { position:absolute; right:.35rem; top:50%; transform:translateY(-50%); display:inline-flex;
  align-items:center; justify-content:center; width:1.8rem; height:1.8rem; padding:0; border:none;
  border-radius:6px; background:none; color:var(--muted); cursor:pointer;
  transition:color var(--dur) var(--ease), background var(--dur) var(--ease); }
.loc-locate:hover { color:var(--indigo); background:var(--indigo-bg); }
/* inline status line: pin + label + subtle Clear, no floating button or emoji */
.loc-status-pin { display:inline-flex; vertical-align:-2px; margin-right:.25rem; color:var(--indigo); }
.loc-clear { margin-left:.5rem; padding:0; border:none; background:none; font:inherit; font-size:.78rem;
  font-weight:600; color:var(--muted); text-decoration:underline; cursor:pointer; }
.loc-clear:hover { color:var(--indigo); }
/* info tooltip on the "Your location" label */
.field-label { display:inline-flex; align-items:center; gap:.3rem; position:relative; }
.info-btn { display:inline-flex; align-items:center; justify-content:center; width:1.1rem; height:1.1rem;
  padding:0; border:none; background:none; color:var(--faint); cursor:pointer; border-radius:50%; }
.info-btn:hover, .info-btn:focus-visible { color:var(--indigo); }
.info-pop { position:absolute; z-index:30; left:0; top:calc(100% + 6px); width:240px; padding:.6rem .7rem;
  font-size:.76rem; font-weight:400; line-height:1.45; text-transform:none; letter-spacing:0;
  color:var(--ink); background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm); box-shadow:var(--shadow-2); }
.info-pop[hidden] { display:none; }
.loc-suggestions { position:absolute; z-index:20; left:0; right:0; top:calc(100% + 4px); margin:0; padding:.25rem;
  list-style:none; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm); box-shadow:var(--shadow-2);
  max-height:240px; overflow:auto; }
.loc-suggestions[hidden] { display:none; }
.loc-suggestion { padding:.5rem .6rem; border-radius:6px; font-size:.85rem; cursor:pointer; }
.loc-suggestion:hover, .loc-suggestion[aria-selected="true"] { background:var(--indigo-bg); color:var(--indigo-strong); }
.location-status { display:flex; align-items:center; margin:.35rem 0 0; min-height:1.1rem; font-size:.78rem; color:var(--ink-2); }
.location-status:empty { display:none; }

/* distance chip */
.chip-distance { background:var(--indigo-bg); color:var(--indigo-strong); }

/* ---------- details, actions ---------- */
.action-row { display:flex; gap:.75rem; margin:1.2rem 0; }
.section-heading button, .action-row button, .role-button, .theme-toggle, .pill-btn { min-height:40px; }
label { color:var(--muted); font-size:.84rem; font-weight:600; }
.filter-bar label { display:grid; gap:.35rem; }

/* ---------- "Your snapshot" rating form ---------- */
.rating-form { margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.rating-form h3 { font-size:1.1rem; font-weight:800; letter-spacing:-.01em; margin:0 0 .2rem; }
.snap-hint { margin:0 0 1.2rem; font-size:.82rem; color:var(--muted); }
.snap-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; margin-bottom:1.2rem; }
.snap-field { display:grid; gap:.45rem; margin-bottom:1.1rem; }
.snap-label { font-size:.72rem; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.04em; }
.star-rating { display:inline-flex; gap:.2rem; }
.star { padding:.15rem; border:none; background:none; color:var(--line); cursor:pointer; line-height:0;
  border-radius:6px; transition:color var(--dur) var(--ease), transform .1s var(--ease); }
.star:hover { color:var(--amber); }
.star.on { color:var(--amber); }
.star:active { transform:scale(.9); }
.star:focus-visible { outline:none; box-shadow:0 0 0 3px var(--indigo-bg); color:var(--amber); }
.pill-group { display:flex; flex-wrap:wrap; gap:.4rem; }
.pill { font-size:.8rem; font-weight:600; padding:.4rem .7rem; border:1px solid var(--line); border-radius:20px;
  background:var(--surface); color:var(--ink-2); cursor:pointer; min-height:34px;
  transition:border-color var(--dur) var(--ease), color var(--dur) var(--ease), background var(--dur) var(--ease); }
.pill:hover { border-color:var(--indigo); color:var(--indigo); }
.pill.on { border-color:var(--indigo); background:var(--indigo); color:#fff; }
.pill:focus-visible { outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px var(--indigo-bg); }
.attestation { display:flex; align-items:flex-start; gap:.6rem; margin-top:.5rem; color:var(--ink); font-weight:500; font-size:.84rem; line-height:1.5; }
.attestation input { flex:none; width:18px; height:18px; margin:.1rem 0 0; accent-color:var(--indigo); }
.rating-form .save { margin-top:1.5rem; min-height:42px; background:var(--indigo); color:#fff; border:none; border-radius:var(--r-sm); padding:.7rem 1.2rem; font-weight:600; cursor:pointer;
  transition:background var(--dur) var(--ease); }
.rating-form .save:hover:not(:disabled) { background:var(--indigo-strong); }
.rating-form .save:disabled { background:var(--line-soft); color:var(--ink-2); cursor:not-allowed; opacity:1; }
.form-message { min-height:1.3rem; margin:.7rem 0 0; color:var(--indigo-strong); }

/* ---------- admin console ---------- */
.admin-panel { margin-top:1.3rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.admin-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.8rem; }
.admin-grid div { display:grid; gap:.25rem; padding:.85rem; border:1px solid var(--line); border-radius:var(--r-md); background:var(--panel); }
.admin-grid span { color:var(--muted); line-height:1.35; }
.application-review-list { display:grid; gap:.6rem; margin-top:.85rem; }
.application-review-item { display:flex; align-items:center; justify-content:space-between; gap:.75rem;
  padding:.8rem; border:1px solid var(--line); border-radius:var(--r-md); background:var(--panel); }
.application-review-item div:first-child { display:grid; gap:.2rem; }
.application-review-item span { color:var(--muted); font-size:.86rem; }
.application-review-item .cpsa-evidence-line { color:var(--text); }
.application-review-actions { display:flex; flex-wrap:wrap; justify-content:flex-end; gap:.6rem; }

/* ---------- empty ---------- */
.empty-state { padding:2.5rem 1rem; color:var(--muted); text-align:center; }

/* ---------- sign-in view ---------- */
.auth-view { display:flex; align-items:center; justify-content:center; min-height:calc(100vh - 80px); padding:2rem 1.25rem; }
.auth-view[hidden] { display:none; }
.auth-card { width:100%; max-width:380px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--shadow-1); padding:2rem 1.75rem; }
.auth-brand { display:grid; justify-items:start; gap:.2rem; margin-bottom:.35rem; }
.auth-brand .brand-mark { display:inline-flex; margin-bottom:.4rem; }
.auth-brand .brand-name { font-weight:700; font-size:1.25rem; letter-spacing:-.015em; color:var(--ink); margin:0; }
.auth-lead { color:var(--muted); font-size:.9rem; margin:.1rem 0 1.4rem; }
.auth-form { display:grid; gap:.85rem; }
.auth-error { margin:0; padding:.55rem .7rem; border-radius:var(--r-sm);
  background:var(--long-bg); color:var(--long); font-size:.84rem; }
.auth-error[hidden] { display:none; }
.auth-submit { width:100%; justify-content:center; min-height:42px; font-size:.9rem; }
.auth-submit[aria-busy="true"] { opacity:.8; }
.auth-forgot { justify-self:center; padding:.2rem .3rem; border:none; background:none;
  color:var(--muted); font-size:.82rem; }
.auth-forgot:disabled { color:var(--faint); cursor:not-allowed; opacity:1; }
.auth-foot { margin:1.5rem 0 0; text-align:center; color:var(--faint); font-size:.78rem; }
.auth-disclaimer { margin:-.7rem 0 1.25rem; color:var(--ink-2); font-size:.82rem; line-height:1.45; }
.legal-links { display:flex; justify-content:center; gap:.85rem; margin-top:.85rem; font-size:.78rem; }
.legal-links a { color:var(--indigo); font-weight:700; text-decoration:none; }
.legal-links a:hover { text-decoration:underline; text-underline-offset:3px; }

/* ---------- legal pages ---------- */
.legal-page { background:var(--surface); }
.legal-main { width:min(100%, 860px); margin-inline:auto; padding:2.5rem 1.5rem 4rem; }
.legal-main h1 { margin:0 0 .45rem; font-size:clamp(2rem, 6vw, 3rem); line-height:1.05; letter-spacing:0; color:var(--ink); }
.legal-main h2 { margin:2rem 0 .7rem; font-size:1.05rem; color:var(--ink); }
.legal-main p, .legal-main li { color:var(--ink-2); line-height:1.65; }
.legal-main ul { padding-left:1.2rem; }
.legal-main a { color:var(--indigo); font-weight:700; }
.legal-meta { margin:0 0 1.5rem; color:var(--muted); font-size:.85rem; }
.legal-callout { padding:1rem; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--panel); }

/* ---------- responsive ---------- */
@media (max-width:920px) {
  .app-header { flex-direction:column; align-items:stretch; gap:.8rem; }
  .header-controls { justify-content:flex-start; }
  .filter-primary { grid-template-columns:1fr 1fr; }
  .filter-primary .field-search, .filter-primary .location-field { grid-column:1 / -1; }
  .filter-actions { grid-column:1 / -1; min-height:0; }
  .advanced-filters { grid-template-columns:1fr; }
  .filter-bar .field { min-width:0; }
  .workspace { grid-template-columns:1fr; min-height:auto; }
  .results-panel { border-right:0; border-bottom:1px solid var(--line); max-height:none; display:block; overflow:visible; }
  .result-list { overflow-y:visible; }
  .metrics-grid, .location-grid, .snap-grid, .admin-grid { grid-template-columns:1fr; }
  .profile-header { flex-direction:column; }
  .source-box { width:100%; }
  .application-review-item, .application-review-actions { flex-direction:column; align-items:stretch; }
}

@media (max-width:560px) {
  .filter-bar { padding-inline:1rem; }
  .filter-primary { grid-template-columns:1fr; }
  .filter-primary .field-search, .filter-primary .location-field, .filter-actions { grid-column:auto; }
  .filter-actions { align-items:stretch; }
  .filter-actions button { flex:1 1 0; justify-content:center; }
}
