/* ============================================================
   Cheboygan County — "The county that keeps the channel open"
   Chart-paper civic design system. See DESIGN-DNA.md.
   Type: Besley (display) + Hanken Grotesk (text), self-hosted.
   Signature accent: buoy red. Motifs: course line, daymarks,
   depth soundings, bearing-ring helm, chart corner ticks.
   ============================================================ */

@font-face {
  font-family: "Besley";
  src: url("/cheboygancounty/assets/fonts/besley-latin-var.woff2") format("woff2");
  font-weight: 400 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Besley";
  src: url("/cheboygancounty/assets/fonts/besley-italic-latin-var.woff2") format("woff2");
  font-weight: 400 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Hanken Grotesk";
  src: url("/cheboygancounty/assets/fonts/hanken-grotesk-latin-var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Hanken Grotesk";
  src: url("/cheboygancounty/assets/fonts/hanken-grotesk-italic-latin-var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

:root {
  /* chart paper */
  --paper: #f6f1e4;
  --paper-2: #efe7d2;
  --paper-3: #e7dcc0;
  /* lake ink */
  --ink: #1b2a32;
  --ink-soft: #33454e;
  --night: #13242e;
  --night-2: #0d1b23;
  /* signature: buoy red (nun buoys, the Mackinaw's hull, the Crib Light lantern) */
  --buoy: #bf2717;
  --buoy-deep: #9c1f10;
  --buoy-bright: #e8765a; /* red for dark rooms */
  /* green can / pine */
  --pine: #2c5343;
  --pine-bright: #9ec9b5; /* pine for dark rooms */
  /* meta */
  --pewter: #5d6a66;
  --line: #cfc4a8;
  --line-strong: #1b2a32;
  --foam: #eef3ec;

  --font-display: "Besley", "Iowan Old Style", Georgia, serif;
  --font-text: "Hanken Grotesk", "Avenir Next", "Segoe UI", system-ui, sans-serif;

  --wrap: 72rem;
  --radius: 4px;
  --shadow-panel: 0.45rem 0.45rem 0 rgba(27, 42, 50, 0.12);
}

/* ---------- reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-text);
  font-size: 1.0625rem;
  line-height: 1.65;
  font-variant-numeric: tabular-nums;
}
img { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.16;
  color: var(--ink);
  margin: 0 0 0.55em;
  letter-spacing: 0;
}
h1 { font-size: clamp(2rem, 4.6vw, 3.1rem); font-weight: 800; }
h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); }
h3 { font-size: 1.18rem; }
p { margin: 0 0 1em; }
a { color: var(--buoy-deep); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 0.16em; }
a:hover { color: var(--buoy); text-decoration-thickness: 2.5px; }
:focus-visible { outline: 3px solid var(--buoy); outline-offset: 2px; border-radius: 2px; }
::selection { background: var(--buoy); color: #fff; }
strong { font-weight: 700; }
hr { border: 0; border-top: 1.5px dashed var(--line); margin: 2rem 0; }
kbd {
  font-family: var(--font-text);
  font-size: 0.78em;
  font-weight: 700;
  border: 1.5px solid var(--ink);
  border-bottom-width: 3px;
  border-radius: 4px;
  padding: 0 0.4em;
  background: var(--paper);
}
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: 0.75rem; top: -4rem; z-index: 200;
  background: var(--ink); color: var(--paper); font-weight: 700;
  padding: 0.6rem 1rem; border-radius: 0 0 6px 6px; transition: top 0.15s;
}
.skip-link:focus { top: 0; color: var(--paper); }

.wrap { max-width: var(--wrap); margin-inline: auto; padding-inline: 1.25rem; }
.section { padding-block: 3.4rem; }
.section--alt { background: var(--paper-2); }
.section--tight { padding-block: 2.2rem; }

/* ---------- motif: course line (dashed route + waypoint) ---------- */
.course {
  position: relative; border: 0;
  border-top: 2px dashed rgba(27, 42, 50, 0.4);
  margin: 0.4rem 0 1.6rem;
}
.course::after {
  content: ""; position: absolute; top: -7px; left: 64%;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--paper); border: 2.5px solid var(--buoy);
}
.course--mid::after { left: 32%; }
.course--night { border-top-color: rgba(246, 241, 228, 0.35); }
.course--night::after { background: var(--night); border-color: var(--buoy-bright); }

/* ---------- motif: daymarks (red nun ▲, green can ■) ---------- */
.dm { display: inline-block; width: 0.72em; height: 0.72em; flex: none; }
.dm--nun { background: var(--buoy); clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.dm--can { background: var(--pine); }
.eyebrow {
  font-size: 0.8rem; font-weight: 800; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-soft); margin: 0 0 0.7rem;
  line-height: 1.7;
}
.eyebrow::before {
  content: ""; display: inline-block; width: 0.68em; height: 0.68em;
  background: var(--buoy); clip-path: polygon(50% 0, 100% 100%, 0 100%);
  margin-right: 0.55em; transform: translateY(0.02em);
}
.eyebrow--can::before { clip-path: none; background: var(--pine); }
.eyebrow--night { color: var(--paper-2); }

/* ---------- motif: chart corner ticks ---------- */
.ticks { position: relative; }
.ticks::before {
  content: ""; position: absolute; inset: 6px; pointer-events: none;
  background:
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) left 0 top 0 / 16px 2px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) left 0 top 0 / 2px 16px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) right 0 top 0 / 16px 2px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) right 0 top 0 / 2px 16px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) left 0 bottom 0 / 16px 2px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) left 0 bottom 0 / 2px 16px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) right 0 bottom 0 / 16px 2px,
    linear-gradient(var(--tick-c, var(--ink)), var(--tick-c, var(--ink))) right 0 bottom 0 / 2px 16px;
  background-repeat: no-repeat;
}

/* ---------- motif: depth soundings ---------- */
.soundings { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.soundings span {
  position: absolute;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: rgba(246, 241, 228, 0.14);
}
.soundings span::after { content: attr(data-n); }
.table-scroll { overflow-x: auto; }
@media (max-width: 1180px) { .soundings { display: none; } }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: var(--font-text); font-weight: 800; font-size: 1rem;
  background: var(--buoy); color: #fff; text-decoration: none;
  border: 2px solid var(--buoy); border-radius: var(--radius);
  padding: 0.62rem 1.25rem; min-height: 44px; cursor: pointer;
}
.btn:hover { background: var(--buoy-deep); border-color: var(--buoy-deep); color: #fff; }
.btn-ink { background: var(--ink); border-color: var(--ink); }
.btn-ink:hover { background: var(--night-2); border-color: var(--night-2); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.btn-paper { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.btn-paper:hover { background: var(--paper-2); border-color: var(--paper-2); color: var(--ink); }
.btn-sm { padding: 0.35rem 0.85rem; min-height: 34px; font-size: 0.9rem; }
.btn-row { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1.3rem; }

/* ---------- tags ---------- */
.tag {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.74rem; font-weight: 800; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--pine); border: 1.5px solid currentColor; border-radius: 3px;
  padding: 0.08rem 0.5rem; background: transparent;
}
.tag::before { content: ""; width: 0.55em; height: 0.55em; background: currentColor; }
.tag--nun { color: var(--buoy-deep); }
.tag--nun::before { clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.tag--plain::before { display: none; }

/* ---------- proto banner ---------- */
.proto-banner {
  background: var(--night); color: var(--paper-2);
  font-size: 0.9rem; padding: 0.55rem 0;
}
.proto-banner .wrap { display: flex; align-items: baseline; gap: 0.6rem; }
.proto-banner .dm { transform: translateY(1px); }
.proto-banner p { margin: 0; }
.proto-banner a { color: #fff; }
.proto-banner a:hover { color: var(--buoy-bright); }

/* ---------- masthead ---------- */
.masthead {
  background: var(--paper);
  border-bottom: 3px double var(--ink);
}
.mast-grid {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-block: 0.95rem;
}
.brand { display: flex; align-items: center; gap: 0.85rem; text-decoration: none; color: var(--ink); }
.brand:hover { color: var(--ink); }
.brand-mark { width: 54px; height: 54px; flex: none; }
.brand-name {
  display: block; font-family: var(--font-display); font-weight: 800;
  font-size: 1.5rem; line-height: 1.05; letter-spacing: -0.01em;
}
.brand-sub {
  display: block; font-size: 0.74rem; font-weight: 700;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--pewter); margin-top: 0.22rem;
}
.mast-utility { display: flex; align-items: center; gap: 0.9rem; }
.mast-phone { text-align: right; text-decoration: none; color: var(--ink); line-height: 1.25; }
.mast-phone span { display: block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--pewter); }
.mast-phone strong { font-size: 1.05rem; font-weight: 800; }
.mast-phone:hover strong { color: var(--buoy); }
.search-open {
  display: inline-flex; align-items: center; gap: 0.55rem;
  font-family: var(--font-text); font-size: 0.95rem; font-weight: 700; color: var(--ink);
  background: var(--paper-2); border: 1.5px solid var(--ink); border-radius: var(--radius);
  padding: 0.5rem 0.9rem; min-height: 44px; cursor: pointer;
}
.search-open:hover { background: var(--ink); color: var(--paper); }
.search-open:hover kbd { border-color: var(--paper); color: var(--paper); background: transparent; }
.search-open svg { width: 17px; height: 17px; }

/* ---------- primary nav: the chart rail ---------- */
.menu-btn {
  display: none; font-family: var(--font-text); font-weight: 800; font-size: 0.95rem;
  color: var(--ink); background: transparent; border: 2px solid var(--ink);
  border-radius: var(--radius); padding: 0.45rem 0.95rem; min-height: 44px; cursor: pointer;
}
.menu-btn[aria-expanded="true"] { background: var(--ink); color: var(--paper); }
.chart-rail { border-top: 1.5px solid var(--ink); background: var(--paper); }
.chart-rail ul {
  list-style: none; margin-inline: auto; padding-block: 0; display: flex; flex-wrap: wrap;
  max-width: var(--wrap); padding-inline: 1.25rem;
}
.chart-rail li { position: relative; }
.chart-rail a {
  display: inline-flex; align-items: center; min-height: 47px;
  padding: 0.45rem 0.95rem; text-decoration: none;
  font-size: 0.86rem; font-weight: 800; letter-spacing: 0.09em; text-transform: uppercase;
  color: var(--ink-soft);
}
.chart-rail a:hover { color: var(--buoy-deep); }
.chart-rail a[aria-current="page"] { color: var(--ink); }
.chart-rail li:first-child a { padding-left: 0; }
.chart-rail li:last-child a { padding-right: 0; }
.chart-rail a[aria-current="page"]::after {
  content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: 0;
  border-left: 7px solid transparent; border-right: 7px solid transparent;
  border-bottom: 8px solid var(--buoy);
}

/* ---------- breadcrumb ---------- */
.crumb { font-size: 0.85rem; color: var(--pewter); padding-block: 0.85rem 0; }
.crumb a { color: var(--pewter); }
.crumb a:hover { color: var(--buoy); }
.crumb .dm { width: 0.5em; height: 0.5em; margin-inline: 0.45rem; transform: translateY(-1px); }

/* ---------- pagehead: chart panel ---------- */
.pagehead {
  background:
    repeating-linear-gradient(0deg, rgba(27, 42, 50, 0.045) 0 1px, transparent 1px 56px),
    repeating-linear-gradient(90deg, rgba(27, 42, 50, 0.045) 0 1px, transparent 1px 56px),
    var(--paper-2);
  border-bottom: 1.5px solid var(--ink);
}
.pagehead .wrap { padding-block: 2.6rem 2.2rem; max-width: 56rem; }
.pagehead .lede { font-size: 1.16rem; color: var(--ink-soft); max-width: 44rem; margin-bottom: 0; }
.pagehead h1 { max-width: 46rem; }
.pagehead .course { margin: 1.5rem 0 0; }

/* ---------- panels ---------- */
.panel {
  background: var(--paper); border: 2px solid var(--ink); border-radius: var(--radius);
  outline: 1px solid var(--ink); outline-offset: 3px;
  box-shadow: var(--shadow-panel);
  padding: 1.5rem 1.6rem;
}
.panel--night {
  background: var(--night); color: var(--paper-2);
  border-color: var(--paper-2); outline-color: var(--paper-2);
}
.panel--night h2, .panel--night h3 { color: #fff; }

/* concept note (honest labeling) */
.note {
  border: 1.5px dashed var(--pewter); border-radius: var(--radius);
  background: rgba(246, 241, 228, 0.65);
  padding: 0.95rem 1.15rem; font-size: 0.92rem; color: var(--ink-soft);
  margin: 1.6rem 0;
}
.note .note-tag {
  display: inline-flex; align-items: center; gap: 0.45rem;
  font-size: 0.72rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--buoy-deep); margin-bottom: 0.35rem;
}
.note .note-tag::before { content: ""; width: 0.62em; height: 0.62em; background: var(--buoy); clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.note p { margin: 0; }
.note p + p { margin-top: 0.5em; }

/* ---------- home hero ---------- */
.hero {
  position: relative; isolation: isolate; color: #fff;
  background: var(--night);
}
.hero .photo {
  position: absolute; inset: 0; z-index: -2;
  background-image: var(--hero-img); background-size: cover; background-position: center 62%;
}
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    repeating-linear-gradient(0deg, rgba(246, 241, 228, 0.07) 0 1px, transparent 1px 72px),
    repeating-linear-gradient(90deg, rgba(246, 241, 228, 0.07) 0 1px, transparent 1px 72px),
    linear-gradient(180deg, rgba(13, 27, 35, 0.62) 0%, rgba(13, 27, 35, 0.4) 45%, rgba(13, 27, 35, 0.78) 100%);
}
.hero .wrap { padding-block: 4.6rem 7.5rem; max-width: 60rem; }
.hero .eyebrow { color: var(--paper-2); }
.hero h1 { color: #fff; font-size: clamp(2.3rem, 5.4vw, 3.7rem); max-width: 17ch; text-wrap: balance; margin-bottom: 0.4em; text-shadow: 0 2px 18px rgba(13, 27, 35, 0.55); }
.hero .lede { font-size: 1.2rem; max-width: 46rem; color: #f1ece0; margin: 0; text-shadow: 0 1px 12px rgba(13, 27, 35, 0.6); }
.hero-credit {
  position: absolute; right: 0.9rem; bottom: 6rem; z-index: 1;
  font-size: 0.72rem; color: rgba(246, 241, 228, 0.85);
}
.hero-credit a { color: inherit; }

/* the counter: chart-table card overlapping the hero */
.counter-dock { margin-top: -5.2rem; position: relative; z-index: 2; padding-bottom: 0.4rem; }
.counter { padding: 1.7rem 1.8rem 1.4rem; }
.counter .counter-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.counter h2 { margin-bottom: 0.2em; }
.counter .hint { font-size: 0.85rem; color: var(--pewter); }
.searchbox { position: relative; display: flex; gap: 0.6rem; margin: 0.9rem 0 0.5rem; }
.searchbox input {
  flex: 1; min-width: 0; font-family: var(--font-text); font-size: 1.08rem; color: var(--ink);
  background: #fffdf6; border: 2px solid var(--ink); border-radius: var(--radius);
  padding: 0.7rem 1rem; min-height: 50px;
}
.searchbox input::placeholder { color: #6b7572; opacity: 1; }
.suggest-list {
  position: absolute; left: 0; right: 0; top: calc(100% + 0.35rem); z-index: 30;
  list-style: none; margin: 0; padding: 0.35rem;
  background: #fffdf6; border: 2px solid var(--ink); border-radius: var(--radius);
  outline: 1px solid var(--ink); outline-offset: 2px;
  box-shadow: 0.35rem 0.35rem 0 rgba(27, 42, 50, 0.16);
  max-height: min(19rem, 56vh); overflow-y: auto;
}
.suggest-list[hidden] { display: none; }
.suggest-list li { margin: 0; }
.suggest-list button {
  width: 100%; min-height: 42px; display: grid; grid-template-columns: 1fr auto;
  gap: 0.35rem 0.75rem; align-items: center; text-align: left;
  border: 0; border-radius: 3px; background: transparent; color: var(--ink);
  font: inherit; padding: 0.52rem 0.65rem; cursor: pointer;
}
.suggest-list button:hover,
.suggest-list button:focus-visible {
  background: rgba(191, 39, 23, 0.08);
}
.suggest-title { font-weight: 800; line-height: 1.25; }
.suggest-meta { font-size: 0.78rem; color: var(--pewter); white-space: nowrap; }
.suggest-list mark {
  background: rgba(232, 118, 90, 0.25); color: inherit; padding-inline: 0.08em;
}
.chips { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.7rem; }
.chip {
  display: inline-flex; align-items: center; min-height: 34px;
  font-family: var(--font-text); font-size: 0.88rem; font-weight: 700; color: var(--ink-soft);
  background: var(--paper-2); border: 1.5px solid var(--line); border-radius: 999px;
  padding: 0.2rem 0.85rem; text-decoration: none; cursor: pointer;
}
.chip:hover { border-color: var(--buoy); color: var(--buoy-deep); background: var(--paper); }

/* ---------- ledger rows ---------- */
.ledger { list-style: none; margin: 0; padding: 0; }
.ledger > li { border-bottom: 1.5px solid var(--line); }
.ledger > li:last-child { border-bottom: 0; }
.ledger-row {
  display: flex; align-items: center; gap: 0.85rem; flex-wrap: wrap;
  padding: 0.78rem 0.15rem;
}
.ledger-row .dm { margin-top: 0; }
.ledger-row .what { font-weight: 700; }
.ledger-row .what .sub { display: block; font-size: 0.86rem; font-weight: 500; color: var(--pewter); }
.ledger-row .leader { flex: 1 1 2rem; border-bottom: 2px dotted var(--line); min-width: 2rem; transform: translateY(0.35em); }
.ledger-row .act { font-weight: 800; white-space: nowrap; }
a.ledger-link { display: block; text-decoration: none; color: var(--ink); }
a.ledger-link:hover { background: rgba(191, 39, 23, 0.05); }
a.ledger-link:hover .act { color: var(--buoy); }
a.ledger-link .act { color: var(--buoy-deep); }

/* ---------- routes: wayfinding by life moment ---------- */
.routes { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; }
.route {
  position: relative; display: block; background: var(--paper);
  border: 1.5px solid var(--ink); border-radius: var(--radius);
  padding: 1.1rem 1.2rem 1rem; color: var(--ink);
}
.route h3 a { color: inherit; text-decoration: none; }
.route h3 a::after { content: ""; position: absolute; inset: 0; }
.route::before {
  content: ""; position: absolute; top: -1.5px; left: 1.1rem;
  border-left: 9px solid transparent; border-right: 9px solid transparent;
  border-top: 11px solid var(--buoy);
}
.route:nth-child(even)::before { border-top-color: var(--pine); }
.route:hover { box-shadow: var(--shadow-panel); }
.route h3 { margin: 0.25rem 0 0.3rem; }
.route p { margin: 0 0 0.5rem; font-size: 0.95rem; color: var(--ink-soft); }
.route .go { font-weight: 800; font-size: 0.92rem; color: var(--buoy-deep); }
.route:hover .go { color: var(--buoy); }

/* ---------- meeting card ---------- */
.meeting-card { padding: 1.35rem 1.45rem; }
.meeting-card .label {
  font-size: 0.74rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase;
  color: var(--buoy-deep); margin: 0 0 0.5rem; display: flex; align-items: center; gap: 0.5rem;
}
.meeting-card .label::before { content: ""; width: 0.62em; height: 0.62em; background: var(--buoy); clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.meeting-card h3 { margin-bottom: 0.1rem; }
.meeting-card .when { font-weight: 800; font-size: 1.06rem; margin: 0 0 0.15rem; }
.meeting-card .where { color: var(--pewter); margin: 0 0 0.8rem; font-size: 0.95rem; }
.meeting-card .small { font-size: 0.78rem; color: var(--pewter); margin: 0.9rem 0 0; }

/* ---------- notices ---------- */
.notice-list { list-style: none; margin: 0; padding: 0; }
.notice-list > li { padding: 1.05rem 0; border-bottom: 1.5px solid var(--line); }
.notice-list > li:last-child { border-bottom: 0; }
.notice-meta { display: flex; align-items: center; gap: 0.7rem; font-size: 0.82rem; color: var(--pewter); margin: 0 0 0.3rem; }
.notice-list h3 { margin: 0 0 0.25rem; font-size: 1.13rem; }
.notice-list h3 a { color: var(--ink); text-decoration: none; }
.notice-list h3 a:hover { color: var(--buoy-deep); text-decoration: underline; text-decoration-thickness: 2.5px; }
.notice-list p { margin: 0; color: var(--ink-soft); font-size: 0.97rem; }

/* ---------- night room: the waterway band & footer ---------- */
.band-night { position: relative; background: var(--night); color: var(--paper-2); overflow: hidden; }
.band-night h2, .band-night h3 { color: #fff; }
.band-night a { color: var(--buoy-bright); }
.band-night a:hover { color: #fff; }
.band-night a.btn-paper { color: var(--ink); }
.band-night a.btn-paper:hover { color: var(--ink); background: var(--paper-2); }
.band-night .lede { color: var(--paper-2); }

.sounding-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; margin-top: 1.8rem; }
.sounding-stats .stat .num {
  display: block; font-family: var(--font-display); font-style: italic; font-weight: 600;
  font-size: clamp(1.9rem, 3.4vw, 2.7rem); color: #fff; line-height: 1.05;
}
.sounding-stats .stat .cap { display: block; font-size: 0.86rem; color: var(--pine-bright); margin-top: 0.3rem; }

/* ---------- figures: chart insets ---------- */
.inset { margin: 0; background: var(--paper); border: 1.5px solid var(--ink); padding: 0.55rem; }
.inset img { width: 100%; height: auto; }
.inset--tall img { max-height: 540px; object-fit: cover; object-position: center 32%; }
.inset figcaption {
  display: flex; flex-wrap: wrap; gap: 0.25rem 0.9rem; justify-content: space-between;
  font-size: 0.76rem; color: var(--pewter); padding: 0.5rem 0.2rem 0.1rem;
}
.inset .coords { font-weight: 800; letter-spacing: 0.04em; color: var(--ink-soft); }
.band-night .inset { border-color: var(--paper-2); background: var(--night-2); }
.band-night .inset figcaption { color: var(--paper-2); }
.band-night .inset .coords { color: var(--pine-bright); }
.photo-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; margin-top: 1.5rem; }
.photo-grid .inset img { aspect-ratio: 4 / 3; object-fit: cover; }

/* ---------- generic split ---------- */
.split { display: grid; grid-template-columns: 1.25fr 1fr; gap: 2.4rem; align-items: start; }
.split--even { grid-template-columns: 1fr 1fr; }

/* ---------- chart table ---------- */
.chart-table { width: 100%; border-collapse: collapse; font-size: 0.97rem; }
.chart-table caption { text-align: left; font-weight: 800; font-family: var(--font-display); font-size: 1.1rem; padding-bottom: 0.6rem; }
.chart-table th {
  text-align: left; font-size: 0.76rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft); border-bottom: 2px solid var(--ink); padding: 0.45rem 0.7rem 0.45rem 0;
}
.chart-table td { border-bottom: 1.5px solid var(--line); padding: 0.6rem 0.7rem 0.6rem 0; vertical-align: top; }
.chart-table tr:last-child td { border-bottom: 0; }

/* ---------- documents finder ---------- */
.finder { display: grid; grid-template-columns: 15.5rem 1fr; gap: 2.2rem; align-items: start; margin-top: 1.8rem; }
.facets { position: sticky; top: 1rem; }
.facets h2 { font-size: 1.05rem; margin-bottom: 0.6rem; }
.facet-group { margin-bottom: 1.3rem; }
.facet-group > p { font-size: 0.76rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); margin: 0 0 0.4rem; border-bottom: 2px solid var(--ink); padding-bottom: 0.3rem; }
.facet { display: flex; align-items: center; gap: 0.5rem; font-size: 0.92rem; padding: 0.22rem 0; cursor: pointer; min-height: 28px; }
.facet input { width: 18px; height: 18px; accent-color: var(--buoy); flex: none; }
.facet .count { margin-left: auto; font-size: 0.78rem; color: var(--pewter); }
.result-count { font-size: 0.92rem; color: var(--pewter); margin: 0 0 1rem; }
.doc-list { list-style: none; margin: 0; padding: 0; }
.doc-item { padding: 1.05rem 0; border-bottom: 1.5px solid var(--line); }
.doc-item:last-child { border-bottom: 0; }
.doc-item h3 { font-size: 1.1rem; margin: 0 0 0.3rem; }
.doc-item h3 a { color: var(--ink); text-decoration: none; }
.doc-item h3 a:hover { color: var(--buoy-deep); text-decoration: underline; text-decoration-thickness: 2.5px; }
.doc-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.6rem; font-size: 0.8rem; color: var(--pewter); margin: 0 0 0.35rem; }
.doc-item > p:last-child { margin: 0; font-size: 0.95rem; color: var(--ink-soft); }
.doc-item:target { background: rgba(191, 39, 23, 0.07); outline: 2px dashed var(--buoy); outline-offset: 6px; }

/* ---------- search dialog (the command bar) ---------- */
.cmdk {
  width: min(46rem, 94vw); border: 2px solid var(--ink); border-radius: 6px;
  outline: 1px solid var(--ink); outline-offset: 3px;
  background: var(--paper); color: var(--ink); padding: 0;
  margin: 9vh auto auto; box-shadow: 0 24px 60px rgba(13, 27, 35, 0.45);
}
.cmdk::backdrop { background: rgba(13, 27, 35, 0.55); }
.cmdk-head { display: flex; gap: 0.6rem; align-items: center; padding: 0.9rem 1rem; border-bottom: 1.5px solid var(--line); }
.cmdk-head svg { width: 20px; height: 20px; flex: none; color: var(--buoy-deep); }
.cmdk-head input {
  flex: 1; min-width: 0; border: 0; background: transparent; color: var(--ink);
  font-family: var(--font-text); font-size: 1.12rem; padding: 0.35rem 0.2rem;
}
.cmdk-head input:focus { outline: none; }
.cmdk-close { flex: none; }
.cmdk-results { max-height: 56vh; overflow-y: auto; padding: 0.5rem 0.6rem 0.7rem; }
.cmdk-status { font-size: 0.85rem; color: var(--pewter); padding: 0.5rem 0.6rem 0.2rem; margin: 0; }
.cmdk-foot {
  display: flex; gap: 1.1rem; flex-wrap: wrap; padding: 0.55rem 1rem;
  border-top: 1.5px solid var(--line); font-size: 0.78rem; color: var(--pewter);
}
.cmdk-foot a { color: var(--buoy-deep); font-weight: 700; }

.result-list { list-style: none; margin: 0; padding: 0; }
.result {
  border: 1.5px solid transparent; border-radius: var(--radius);
  padding: 0.65rem 0.75rem; margin: 0.15rem 0;
}
.result.is-active { border-color: var(--buoy); background: rgba(191, 39, 23, 0.06); }
.result h3 { font-family: var(--font-text); font-size: 1.02rem; margin: 0 0 0.15rem; }
.result h3 a { color: var(--ink); text-decoration: none; }
.result h3 a:hover { color: var(--buoy-deep); }
.result .r-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.55rem; font-size: 0.78rem; color: var(--pewter); margin: 0 0 0.2rem; }
.result .r-excerpt { font-size: 0.9rem; color: var(--ink-soft); margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.result-actions { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.45rem; }
.result-actions a {
  display: inline-flex; align-items: center; gap: 0.35rem; min-height: 30px;
  font-size: 0.82rem; font-weight: 800; text-decoration: none;
  color: var(--buoy-deep); border: 1.5px solid var(--buoy-deep); border-radius: 999px;
  padding: 0.1rem 0.7rem;
}
.result-actions a:hover { background: var(--buoy); border-color: var(--buoy); color: #fff; }
.rel {
  font-size: 0.74rem; font-weight: 800; color: var(--pine);
  border: 1.5px solid currentColor; border-radius: 3px; padding: 0 0.35rem;
}

/* search page variant */
.search-hero .searchbox input { min-height: 56px; font-size: 1.15rem; }
.api-doc {
  background: var(--night); color: var(--paper-2); border-radius: 6px;
  padding: 1.2rem 1.4rem; font-size: 0.9rem; overflow-x: auto;
}
.api-doc code { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.86em; }
.api-doc pre { margin: 0.6rem 0 0; white-space: pre; }
.api-doc .c { color: var(--pine-bright); }
.api-doc .k { color: var(--buoy-bright); }

/* ---------- accessibility scoreboard ---------- */
.score-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.3rem; margin: 1.6rem 0; }
.score-card { text-align: center; padding: 1.5rem 1rem 1.3rem; }
.score-card .n { display: block; font-family: var(--font-display); font-weight: 800; font-size: 3.4rem; line-height: 1; }
.score-card .n--bad { color: var(--buoy-deep); }
.score-card .n--good { color: var(--pine); }
.score-card .l { display: block; font-size: 0.88rem; color: var(--ink-soft); margin-top: 0.45rem; }
.findings { list-style: none; margin: 1rem 0 0; padding: 0; }
.findings li { display: grid; grid-template-columns: 1fr auto; gap: 0.3rem 1rem; padding: 0.7rem 0.15rem; border-bottom: 1.5px solid var(--line); }
.findings li:last-child { border-bottom: 0; }
.findings .f-what { font-weight: 700; }
.findings .f-what .sub { display: block; font-weight: 500; font-size: 0.88rem; color: var(--pewter); }
.findings .f-count { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; color: var(--buoy-deep); align-self: center; }
.bar { grid-column: 1 / -1; height: 9px; background: var(--paper-2); border: 1px solid var(--line); border-radius: 99px; overflow: hidden; }
.bar i { display: block; height: 100%; background: var(--buoy); }

/* ---------- contact ledger ---------- */
.phone-ledger .ledger-row { padding-block: 0.65rem; }
.phone-ledger .who { font-weight: 700; }
.phone-ledger .who .sub { display: block; font-size: 0.84rem; font-weight: 500; color: var(--pewter); }
.phone-ledger a.tel { font-weight: 800; white-space: nowrap; }
a[href^="tel:"] { white-space: nowrap; }
.eyebrow a[href^="tel:"],
.lead-name a[href^="tel:"] {
  color: inherit;
  text-decoration-color: rgba(27, 42, 50, 0.28);
}
.eyebrow a[href^="tel:"]:hover,
.lead-name a[href^="tel:"]:hover { color: var(--buoy-deep); }

/* ---------- dept directory ---------- */
.dept { padding: 1.5rem 0 1.2rem; border-bottom: 2px solid var(--line); scroll-margin-top: 1rem; }
.dept:last-child { border-bottom: 0; }
.dept-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 0.4rem; }
.dept-head h3 { margin: 0; font-size: 1.3rem; }
.dept-head .reach { font-size: 0.95rem; }
.dept .lead-name { font-size: 0.9rem; color: var(--pewter); margin: 0 0 0.5rem; }
.dept ul.tasks { margin: 0.5rem 0 0; padding: 0; list-style: none; display: flex; flex-wrap: wrap; gap: 0.45rem 1.4rem; }
.dept ul.tasks li { display: flex; align-items: center; gap: 0.5rem; font-size: 0.95rem; }
.dept ul.tasks li::before { content: ""; flex: none; width: 0.55em; height: 0.55em; background: var(--pine); }
.dept ul.tasks li:nth-child(odd)::before { background: var(--buoy); clip-path: polygon(50% 0, 100% 100%, 0 100%); }

/* ---------- footer: the anchorage ---------- */
.anchorage { position: relative; background: var(--night); color: var(--paper-2); margin-top: 4rem; }
.anchorage::before { content: ""; position: absolute; inset: 0 0 auto; height: 6px; background: var(--buoy); }
.anchorage .wrap { position: relative; }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2.2rem; padding-block: 3rem 2rem; }
.foot-brand .brand-name { color: #fff; font-size: 1.35rem; }
.foot-brand .brand-sub { color: var(--pine-bright); }
.foot-brand p { font-size: 0.95rem; margin-top: 0.9rem; }
.foot-brand .coords { font-size: 0.8rem; color: var(--pine-bright); letter-spacing: 0.05em; }
.anchorage h2 { color: #fff; font-family: var(--font-text); font-size: 0.78rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; border-bottom: 1.5px solid rgba(246, 241, 228, 0.3); padding-bottom: 0.45rem; }
.anchorage ul { list-style: none; margin: 0; padding: 0; }
.anchorage li { margin: 0.45rem 0; }
.anchorage a { color: var(--paper-2); text-decoration-color: rgba(246, 241, 228, 0.4); }
.anchorage a:hover { color: #fff; text-decoration-color: var(--buoy-bright); }
.foot-bottom {
  display: flex; flex-wrap: wrap; gap: 0.5rem 2rem; justify-content: space-between;
  border-top: 1.5px solid rgba(246, 241, 228, 0.25); padding-block: 1.1rem 1.4rem;
  font-size: 0.82rem; color: rgba(246, 241, 228, 0.75);
}
.foot-bottom a { color: var(--paper-2); }

/* keyboard hints are noise on touch devices */
@media (hover: none) and (pointer: coarse) {
  .counter .hint { display: none; }
}

/* ---------- helpers ---------- */
.lede { font-size: 1.14rem; color: var(--ink-soft); }
.max-prose { max-width: 46rem; }
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.center { text-align: center; }
.section-head { max-width: 46rem; margin-bottom: 1.7rem; }
.section-head h2 { margin-bottom: 0.3em; }
.section-head p { color: var(--ink-soft); margin: 0; }

/* ---------- responsive ---------- */
@media (max-width: 980px) {
  .split, .split--even { grid-template-columns: 1fr; gap: 1.8rem; }
  .sounding-stats { grid-template-columns: repeat(2, 1fr); }
  .finder { grid-template-columns: 1fr; }
  .facets { position: static; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
  .menu-btn { display: inline-flex; align-items: center; }
  .chart-rail ul { display: none; flex-direction: column; padding-block: 0.4rem; }
  .chart-rail ul.open { display: flex; }
  .chart-rail a { min-height: 44px; width: 100%; }
  .chart-rail li:first-child a { padding-left: 0.95rem; }
  .chart-rail li:last-child a { padding-right: 0.95rem; }
  .chart-rail a[aria-current="page"]::after {
    left: auto; right: 1rem; bottom: auto; top: 50%;
    transform: translateY(-35%);
  }
  .mast-phone { display: none; }
  .routes { grid-template-columns: 1fr; }
  .score-cards { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .section { padding-block: 2.6rem; }
  .hero .wrap { padding-block: 3.2rem 9.2rem; }
  .hero-credit { left: 1.25rem; right: 1.25rem; bottom: 5.9rem; text-align: right; }
  .counter { padding: 1.2rem 1.1rem 1rem; }
  .searchbox { flex-direction: column; }
  .searchbox .btn { width: 100%; }
  .sounding-stats { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .photo-grid { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr; gap: 1.4rem; }
  .brand-mark { width: 44px; height: 44px; }
  .brand-name { font-size: 1.25rem; }
  .brand-sub { font-size: 0.64rem; letter-spacing: 0.08em; }
  .search-open .label { display: none; }
  .search-open kbd { display: none; }
}

/* ---------- print (Appendix A item D: printer-friendly) ---------- */
@media print {
  .proto-banner, .chart-rail, .mast-utility, .skip-link, .crumb,
  .anchorage .foot-grid > :not(.foot-brand), .btn, .chips, .cmdk { display: none !important; }
  body { background: #fff; color: #000; font-size: 11pt; }
  .masthead { border-bottom: 2px solid #000; }
  .hero, .band-night, .pagehead, .section--alt { background: #fff !important; color: #000 !important; }
  .hero h1, .band-night h2, .band-night h3 { color: #000 !important; text-shadow: none; }
  .hero::before, .hero .photo, .soundings { display: none; }
  a { color: #000; }
  .panel { box-shadow: none; outline: none; }
}
