/* ==========================================================================
   Chelle on Wheels — Notary Journal theme
   --------------------------------------------------------------------------
   Visual language:  Mobile-notary journal book / signing kit logbook.
                     Friendly, document-grounded, warm without being yellow.
   Type pairing:     Fraunces (display) + Nunito (body) + Geist Mono (data)
   Colors:           Cool mist white + prussian deep blue + dust rose + sage.
   Class prefix:     cow-* (chelle-on-wheels)
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght,SOFT,WONK@9..144,400;9..144,500;9..144,600;9..144,700&family=Nunito:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap');

:root {
  --cow-paper: #ecedea;
  --cow-paper-deep: #dde0dc;
  --cow-paper-row: #cdd1cc;
  --cow-paper-warm: #f4f5f2;
  --cow-ink: #1f3a5f;
  --cow-ink-soft: #2c4a6e;
  --cow-ink-fade: #5d6f86;
  --cow-rule: #a0a3a0;
  --cow-rule-soft: #c2c5c1;
  --cow-rose: #c4778a;
  --cow-rose-deep: #9c5a6c;
  --cow-rose-soft: #efd4dc;
  --cow-sage: #7a8d6e;
  --cow-sage-soft: #c1cfb9;
  --cow-shadow: 0 16px 32px -22px rgba(31, 58, 95, 0.45);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { overflow-x: clip; max-width: 100vw; }
html { scroll-behavior: smooth; }

body {
  background: var(--cow-paper);
  color: var(--cow-ink);
  font-family: 'Nunito', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Soft journal-page lines */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: linear-gradient(180deg, transparent 0 31px, rgba(31, 58, 95, 0.04) 31px 32px);
  background-size: 32px 32px;
  pointer-events: none;
  z-index: 0;
}
body > * { position: relative; z-index: 1; }

a { color: var(--cow-ink); text-decoration: underline; text-decoration-color: var(--cow-rose); text-underline-offset: 4px; text-decoration-thickness: 1.5px; }
a:hover { color: var(--cow-rose-deep); }

/* ==========================================================================
   Type
   ========================================================================== */

.cow-display {
  font-family: 'Fraunces', 'Times New Roman', serif;
  font-weight: 600;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.cow-display em { font-style: italic; color: var(--cow-rose-deep); font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1; }

.cow-mono {
  font-family: 'Geist Mono', 'Courier New', monospace;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.cow-eyebrow {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
}

/* ==========================================================================
   Layout shell
   ========================================================================== */

.cow-page { min-height: 100vh; display: flex; flex-direction: column; }

.cow-shell { width: min(1240px, 100% - 64px); margin: 0 auto; }

@media (max-width: 760px) {
  .cow-shell { width: calc(100% - 32px); }
}

/* ==========================================================================
   Header
   ========================================================================== */

.cow-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--cow-paper);
  border-bottom: 1px solid var(--cow-ink);
}
.cow-header__strip {
  background: var(--cow-ink);
  color: var(--cow-paper);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 7px 0;
}
.cow-header__strip-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.cow-header__strip-row span:nth-child(2) { color: var(--cow-rose-soft); opacity: 0.95; }
.cow-header__strip-row span:nth-child(3) { color: var(--cow-sage-soft); }

.cow-header__main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0;
}
.cow-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: var(--cow-ink);
}
.cow-brand img,
.cow-brand svg { width: 56px; height: 56px; }
.cow-brand__words {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1;
}
.cow-brand__name {
  font-family: 'Fraunces', serif;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.01em;
  font-variation-settings: 'opsz' 144;
}
.cow-brand__tag {
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}

.cow-nav { display: flex; gap: 26px; align-items: center; }
.cow-nav a {
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  color: var(--cow-ink);
  position: relative;
  padding: 4px 0;
}
.cow-nav a:hover { color: var(--cow-rose-deep); }
.cow-nav a[data-current="1"]::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2.5px;
  background: var(--cow-rose);
  border-radius: 2px;
}

/* Mobile burger drawer */
.cow-burger {
  display: none;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1.5px solid var(--cow-ink);
  border-radius: 8px;
  cursor: pointer;
  padding: 0;
  align-items: center;
  justify-content: center;
}
.cow-burger-toggle { display: none; }
.cow-burger-bars {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  width: 18px;
  height: 14px;
  pointer-events: none;
}
.cow-burger-bars span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--cow-ink);
  border-radius: 2px;
  transition: transform 0.24s ease, opacity 0.24s ease;
}
.cow-drawer-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(31, 58, 95, 0.5);
  z-index: 90;
}
.cow-drawer {
  position: fixed;
  top: 0;
  right: -100%;
  width: 320px;
  height: 100vh;
  height: 100dvh;
  background: var(--cow-paper-warm);
  border-left: 4px solid var(--cow-rose);
  box-shadow: -16px 0 40px -8px rgba(31, 58, 95, 0.35);
  padding: 32px 28px;
  transition: right 0.28s ease;
  z-index: 100;
  overflow-y: auto;
}
.cow-drawer__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
  padding-bottom: 18px;
  border-bottom: 1px dashed var(--cow-rule-soft);
}
.cow-drawer__close-btn {
  width: 32px; height: 32px;
  border: 1.5px solid var(--cow-ink);
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  position: relative;
}
.cow-drawer__close-btn::before,
.cow-drawer__close-btn::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 16px; height: 2px;
  background: var(--cow-ink);
  border-radius: 2px;
}
.cow-drawer__close-btn::before { transform: translate(-50%, -50%) rotate(45deg); }
.cow-drawer__close-btn::after { transform: translate(-50%, -50%) rotate(-45deg); }

.cow-drawer__nav { display: flex; flex-direction: column; gap: 4px; }
.cow-drawer__nav a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 600;
  text-decoration: none;
  color: var(--cow-ink);
  border-bottom: 1px solid var(--cow-rule-soft);
}
.cow-drawer__nav a::after {
  content: '→';
  font-family: 'Geist Mono', monospace;
  color: var(--cow-rose);
  opacity: 0;
  transition: opacity 0.2s ease;
}
.cow-drawer__nav a:hover { color: var(--cow-rose-deep); }
.cow-drawer__nav a:hover::after { opacity: 1; }
.cow-drawer__cta {
  display: block;
  margin-top: 26px;
  padding: 14px;
  background: var(--cow-ink);
  color: var(--cow-paper);
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: center;
  text-decoration: none;
  border-radius: 10px;
}

.cow-burger-toggle:checked ~ .cow-drawer { right: 0; }
.cow-burger-toggle:checked ~ .cow-drawer-backdrop { display: block; }
.cow-burger-toggle:checked ~ .cow-header .cow-burger-bars span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.cow-burger-toggle:checked ~ .cow-header .cow-burger-bars span:nth-child(2) { opacity: 0; }
.cow-burger-toggle:checked ~ .cow-header .cow-burger-bars span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
body:has(.cow-burger-toggle:checked) { overflow: hidden; }

/* ==========================================================================
   Detail page grid (8/4)
   ========================================================================== */

.cow-detail {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 56px;
  padding: 36px 0 88px;
}
.cow-main { min-width: 0; }
.cow-aside { align-self: start; }

/* ==========================================================================
   Journal cover page (Section 01)
   ========================================================================== */

.cow-cover {
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  padding: 48px 48px 44px;
  position: relative;
  margin-bottom: 32px;
  border-radius: 6px;
}
.cow-cover::before {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px dashed var(--cow-rule-soft);
  pointer-events: none;
  border-radius: 4px;
}
.cow-cover__chapter {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  background: var(--cow-ink);
  color: var(--cow-paper);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 100px;
}
.cow-cover__chapter span { color: var(--cow-rose-soft); }

.cow-cover__name {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-variation-settings: 'opsz' 144, 'SOFT' 60;
  font-size: clamp(38px, 5.5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.015em;
  color: var(--cow-ink);
  margin: 16px 0 16px;
}

.cow-cover__loc {
  font-family: 'Nunito', sans-serif;
  font-size: 17px;
  color: var(--cow-ink-soft);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.cow-cover__loc strong { font-weight: 700; color: var(--cow-ink); }
.cow-cover__loc span.divider { color: var(--cow-rose); font-weight: 700; }

.cow-cover__tier {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 5px 12px;
  background: var(--cow-rose-soft);
  color: var(--cow-rose-deep);
  border: 1px solid var(--cow-rose);
  border-radius: 100px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.cow-cover__tier[data-on="0"] {
  background: transparent;
  color: var(--cow-ink-fade);
  border-color: var(--cow-rule);
}
.cow-cover__tier[data-on="0"]::before { content: '○ '; }
.cow-cover__tier[data-on="1"]::before { content: '● '; color: var(--cow-rose); }

.cow-cover__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}
.cow-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  border: 1.5px solid var(--cow-ink);
  background: var(--cow-paper);
  color: var(--cow-ink);
  border-radius: 100px;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, transform 0.16s ease;
}
.cow-btn::after { content: '→'; font-family: 'Geist Mono', monospace; font-weight: 700; }
.cow-btn:hover { transform: translateY(-1px); background: var(--cow-paper-warm); color: var(--cow-rose-deep); }
.cow-btn--rose { background: var(--cow-rose); color: #fff; border-color: var(--cow-rose-deep); }
.cow-btn--rose:hover { background: var(--cow-rose-deep); color: #fff; }
.cow-btn--ink { background: var(--cow-ink); color: var(--cow-paper); border-color: var(--cow-ink); }
.cow-btn--ink:hover { background: var(--cow-ink-soft); color: var(--cow-paper); }

/* signature line at the bottom of the cover */
.cow-cover__sig {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1.5px solid var(--cow-ink);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}
.cow-cover__sig strong { color: var(--cow-ink); font-weight: 600; }
.cow-cover__sig span:last-child { color: var(--cow-rose-deep); }

/* ==========================================================================
   Photo bay
   ========================================================================== */

.cow-photobay {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 32px;
}
.cow-photobay__cell {
  position: relative;
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
  background: var(--cow-paper-deep);
  overflow: hidden;
  aspect-ratio: 4/3;
}
.cow-photobay__cell--lead { grid-row: span 2; aspect-ratio: 5/6; }
.cow-photobay__cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.cow-photobay__cell::after {
  content: attr(data-tag);
  position: absolute;
  top: 10px; left: 10px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--cow-ink);
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  padding: 3px 8px;
  text-transform: uppercase;
  border-radius: 4px;
}

/* Adaptive photo-count variants */
.cow-photobay--single { grid-template-columns: minmax(0, 1fr); }
.cow-photobay--single .cow-photobay__cell { aspect-ratio: 16/9; }
.cow-photobay--pair { grid-template-columns: 1fr 1fr; }
.cow-photobay--pair .cow-photobay__cell { aspect-ratio: 4/3; }
.cow-photobay--trio { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cow-photobay--trio .cow-photobay__cell { aspect-ratio: 4/3; }

/* Empty-state — branded placeholder, not a stock-photo dump */
.cow-photobay--empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  background:
    repeating-linear-gradient(
      0deg,
      transparent 0 32px,
      rgba(31,58,95,0.04) 32px 33px
    ),
    var(--cow-paper-warm);
  border: 1px solid var(--cow-rule-soft);
  border-radius: 8px;
  padding: 56px 32px;
  margin-bottom: 32px;
  text-align: center;
}
.cow-photobay--empty svg { opacity: 0.55; }
.cow-photobay__empty-eyebrow {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
  font-weight: 600;
}
.cow-photobay__empty-copy {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--cow-ink-soft);
  max-width: 52ch;
  margin: 0;
}

/* ==========================================================================
   Section primitives
   ========================================================================== */

.cow-section {
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
  margin-bottom: 32px;
  position: relative;
  overflow: hidden;
}
.cow-section__head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px 28px;
  background: var(--cow-paper-deep);
  border-bottom: 1px solid var(--cow-ink);
}
.cow-section__num {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  background: var(--cow-ink);
  color: var(--cow-paper);
  padding: 4px 10px;
  border-radius: 100px;
}
.cow-section__title {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.005em;
  font-variation-settings: 'opsz' 30;
}
.cow-section__sub {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}
.cow-section__body { padding: 28px 32px; }
.cow-section__body p { font-size: 16px; color: var(--cow-ink-soft); margin-bottom: 14px; line-height: 1.65; }
.cow-section__body p:last-child { margin-bottom: 0; }
.cow-section__body p strong { color: var(--cow-ink); }
.cow-section__body a { color: var(--cow-rose-deep); }

/* Limited record callout */
.cow-limited {
  background: var(--cow-rose-soft);
  border: 1px dashed var(--cow-rose-deep);
  border-radius: 6px;
  padding: 18px 24px;
  margin-bottom: 32px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}
.cow-limited::before {
  content: 'TIER C';
  font-family: 'Geist Mono', monospace;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  background: var(--cow-rose-deep);
  color: var(--cow-paper);
  padding: 7px 12px;
  border-radius: 100px;
  white-space: nowrap;
}
.cow-limited p {
  font-size: 14px;
  color: var(--cow-ink-soft);
  margin: 0;
  line-height: 1.55;
}

/* ==========================================================================
   Signing-need matrix (5 cards)
   ========================================================================== */

.cow-needs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 28px 32px;
}
.cow-need {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 16px;
  padding: 18px;
  background: var(--cow-paper);
  border: 1px solid var(--cow-rule-soft);
  border-radius: 8px;
  position: relative;
}
.cow-need[data-detected="1"] {
  background: var(--cow-paper-warm);
  border-color: var(--cow-ink);
  border-width: 1.5px;
}
.cow-need[data-detected="1"]::after {
  content: '✓';
  position: absolute;
  top: 12px; right: 12px;
  width: 24px; height: 24px;
  background: var(--cow-rose);
  color: #fff;
  border-radius: 50%;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cow-need__icon {
  width: 56px; height: 56px;
  border: 1.5px solid var(--cow-ink);
  background: var(--cow-paper);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--cow-ink);
}
.cow-need[data-detected="0"] .cow-need__icon {
  color: var(--cow-rule);
  background: transparent;
  border-color: var(--cow-rule);
  border-style: dashed;
}
.cow-need__body { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.cow-need__title {
  font-family: 'Fraunces', serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.15;
}
.cow-need[data-detected="0"] .cow-need__title { color: var(--cow-ink-fade); }
.cow-need__src {
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
}
.cow-need[data-detected="0"] .cow-need__src { color: var(--cow-ink-fade); }
.cow-need__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--cow-ink-soft);
  margin-top: 4px;
}
.cow-need[data-detected="0"] .cow-need__desc { color: var(--cow-ink-fade); }

/* ==========================================================================
   Where they sign — service area pickup card
   ========================================================================== */

.cow-where { padding: 28px 32px; display: grid; grid-template-columns: 7fr 5fr; gap: 24px; align-items: stretch; }
.cow-map {
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
  background: var(--cow-paper-deep);
  position: relative;
  min-height: 320px;
  overflow: hidden;
}
.cow-map iframe { display: block; width: 100%; height: 100%; min-height: 320px; border: 0; }
.cow-map__tag {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--cow-paper-warm);
  color: var(--cow-ink);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  text-transform: uppercase;
  border: 1px solid var(--cow-ink);
  border-radius: 100px;
}
.cow-where__card {
  background: var(--cow-paper);
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cow-where__card dt {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
  margin-bottom: 4px;
}
.cow-where__card dd { font-size: 15px; color: var(--cow-ink); margin-bottom: 12px; line-height: 1.5; }
.cow-where__card dd:last-child { margin-bottom: 0; }
.cow-where__card a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--cow-rose-deep);
  font-weight: 700;
}

/* ==========================================================================
   Evidence ledger (entries from official site)
   ========================================================================== */

.cow-ledger { padding: 28px 32px; display: flex; flex-direction: column; gap: 14px; }
.cow-ledger__row {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 18px;
  padding: 18px 20px;
  background: var(--cow-paper);
  border-left: 4px solid var(--cow-rose);
  border-top: 1px solid var(--cow-rule-soft);
  border-right: 1px solid var(--cow-rule-soft);
  border-bottom: 1px solid var(--cow-rule-soft);
  border-radius: 0 6px 6px 0;
}
.cow-ledger__no {
  font-family: 'Geist Mono', monospace;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--cow-ink-fade);
  border-right: 1px dashed var(--cow-rule-soft);
  padding-right: 12px;
}
.cow-ledger__quote {
  font-family: 'Fraunces', serif;
  font-size: 16.5px;
  line-height: 1.5;
  color: var(--cow-ink);
  font-style: italic;
  font-weight: 500;
}
.cow-ledger__src {
  display: inline-block;
  margin-top: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
  font-style: normal;
}

/* ==========================================================================
   Source attribution table
   ========================================================================== */

.cow-attribution { padding: 28px 32px; }
.cow-attribution table { width: 100%; border-collapse: collapse; font-size: 14px; }
.cow-attribution thead th {
  text-align: left;
  padding: 12px 14px;
  background: var(--cow-ink);
  color: var(--cow-paper);
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.cow-attribution thead th:first-child { border-radius: 6px 0 0 0; }
.cow-attribution thead th:last-child { border-radius: 0 6px 0 0; }
.cow-attribution tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--cow-rule-soft);
  vertical-align: top;
  color: var(--cow-ink-soft);
}
.cow-attribution tbody tr:nth-child(odd) td { background: var(--cow-paper); }
.cow-attribution tbody td:first-child {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  color: var(--cow-ink);
}
.cow-attribution__src {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
}

/* ==========================================================================
   Booking lanes (3-column)
   ========================================================================== */

.cow-lanes { padding: 28px 32px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.cow-lane {
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  background: var(--cow-paper);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cow-lane__no {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
  font-weight: 600;
}
.cow-lane__title {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.05;
  font-variation-settings: 'opsz' 60, 'SOFT' 100;
}
.cow-lane__best {
  font-size: 14px;
  color: var(--cow-ink-soft);
  border-bottom: 1px dashed var(--cow-rule-soft);
  padding-bottom: 12px;
}
.cow-lane__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.cow-lane__list li {
  font-size: 14px;
  color: var(--cow-ink-soft);
  padding-left: 20px;
  position: relative;
  line-height: 1.5;
}
.cow-lane__list li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cow-sage);
}

/* ==========================================================================
   State-rule paragraphs
   ========================================================================== */

.cow-stateblock { padding: 28px 32px; }
.cow-stateblock h3 {
  font-family: 'Fraunces', serif;
  font-size: 19px;
  font-weight: 600;
  color: var(--cow-ink);
  margin-bottom: 8px;
  padding-left: 14px;
  border-left: 4px solid var(--cow-sage);
  font-variation-settings: 'opsz' 50;
}
.cow-stateblock p { font-size: 15px; line-height: 1.65; color: var(--cow-ink-soft); margin-bottom: 16px; }

/* ==========================================================================
   DIY spectrum (4 colored rows)
   ========================================================================== */

.cow-diy { padding: 28px 32px; display: flex; flex-direction: column; gap: 8px; }
.cow-diy__row {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 14px 18px;
  border-radius: 8px;
  border-left: 6px solid var(--cow-rule-soft);
  background: var(--cow-paper);
}
.cow-diy__row[data-tier="diy"] { border-left-color: var(--cow-sage); }
.cow-diy__row[data-tier="sometimes"] { border-left-color: var(--cow-rose-soft); }
.cow-diy__row[data-tier="counter"] { border-left-color: var(--cow-rose); }
.cow-diy__row[data-tier="counter-only"] { border-left-color: var(--cow-ink); background: var(--cow-paper-warm); }
.cow-diy__label {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-weight: 600;
  color: var(--cow-ink);
}
.cow-diy__copy { font-size: 14px; color: var(--cow-ink-soft); line-height: 1.55; }

/* ==========================================================================
   FAQ
   ========================================================================== */

.cow-faq { padding: 14px 32px 28px; }
.cow-faq details {
  border-bottom: 1px solid var(--cow-rule-soft);
  padding: 16px 0;
}
.cow-faq summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-family: 'Fraunces', serif;
  font-size: 19px;
  font-weight: 600;
  color: var(--cow-ink);
}
.cow-faq summary::-webkit-details-marker { display: none; }
.cow-faq summary::after {
  content: '+';
  font-family: 'Geist Mono', monospace;
  font-size: 22px;
  color: var(--cow-rose);
  width: 28px;
  text-align: center;
}
.cow-faq details[open] summary::after { content: '−'; }
.cow-faq details > p {
  margin-top: 12px;
  font-size: 15px;
  color: var(--cow-ink-soft);
  line-height: 1.7;
}

/* ==========================================================================
   Nearby notaries
   ========================================================================== */

.cow-nearby { padding: 28px 32px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.cow-nearby__card {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  background: var(--cow-paper);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  text-decoration: none;
  color: var(--cow-ink);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}
.cow-nearby__card:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 0 var(--cow-rose); }
.cow-nearby__thumb {
  aspect-ratio: 1 / 1;
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
  background-size: cover;
  background-position: center;
  background-color: var(--cow-paper-deep);
}
.cow-nearby__name {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.005em;
}
.cow-nearby__meta {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--cow-ink-fade);
  margin-top: 6px;
}

/* ==========================================================================
   Sidebar
   ========================================================================== */

.cow-aside-stack { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 100px; }
.cow-card {
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  padding: 22px;
  position: relative;
}
.cow-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-bottom: 12px;
  margin-bottom: 14px;
  border-bottom: 1px dashed var(--cow-rule-soft);
}
.cow-card__title {
  font-family: 'Fraunces', serif;
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.cow-card__tag {
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}

.cow-card__row {
  display: grid;
  grid-template-columns: 100px minmax(0, 1fr);
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px dashed var(--cow-rule-soft);
  font-size: 14px;
}
.cow-card__row:last-child { border-bottom: 0; }
.cow-card__row dt {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
  align-self: center;
}
.cow-card__row dd { color: var(--cow-ink); line-height: 1.45; word-break: break-word; }
.cow-card__row dd a { color: var(--cow-rose-deep); }

.cow-card__hours {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 8px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 7px 0;
  border-bottom: 1px dashed var(--cow-rule-soft);
  text-transform: uppercase;
}
.cow-card__hours:last-child { border-bottom: 0; }
.cow-card__hours strong { color: var(--cow-ink); font-weight: 700; }
.cow-card__hours span { color: var(--cow-ink-soft); }

.cow-card__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; counter-reset: item; }
.cow-card__list li {
  position: relative;
  padding-left: 24px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--cow-ink-soft);
}
.cow-card__list li::before {
  counter-increment: item;
  content: counter(item);
  position: absolute;
  left: 0; top: 1px;
  width: 18px; height: 18px;
  background: var(--cow-rose);
  color: #fff;
  border-radius: 50%;
  font-family: 'Nunito', sans-serif;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cow-card--ink {
  background: var(--cow-ink);
  color: var(--cow-paper);
  border-color: var(--cow-ink);
}
.cow-card--ink .cow-card__title { color: var(--cow-rose-soft); }
.cow-card--ink .cow-card__tag { color: var(--cow-paper); opacity: 0.7; }
.cow-card--ink .cow-card__head { border-bottom-color: rgba(255,255,255,0.18); }
.cow-card--ink .cow-card__row { border-bottom-color: rgba(255,255,255,0.16); }
.cow-card--ink .cow-card__row dt { color: var(--cow-rose-soft); }
.cow-card--ink .cow-card__row dd { color: var(--cow-paper); }
.cow-card--ink .cow-card__row dd a { color: var(--cow-rose-soft); }
.cow-card--ink .cow-card__list li { color: var(--cow-paper); }
.cow-card--ink .cow-card__list li::before { background: var(--cow-rose-soft); color: var(--cow-ink); }

.cow-card__cover {
  margin: -22px -22px 14px;
  height: 160px;
  background-size: cover;
  background-position: center;
  border-bottom: 1px solid var(--cow-ink);
  border-radius: 8px 8px 0 0;
}
.cow-card__cover-empty {
  margin: -22px -22px 14px;
  height: 100px;
  background: var(--cow-paper-deep);
  border-bottom: 1px solid var(--cow-ink);
  border-radius: 8px 8px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}

/* ==========================================================================
   Footer
   ========================================================================== */

.cow-footer {
  background: var(--cow-ink);
  color: var(--cow-paper);
  margin-top: 64px;
  padding: 64px 0 32px;
}
.cow-footer h3 {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-weight: 600;
  color: var(--cow-rose-soft);
  margin-bottom: 16px;
  letter-spacing: -0.005em;
}
.cow-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1.2fr 1fr;
  gap: 56px;
  align-items: start;
}
.cow-footer__states {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px 18px;
}
.cow-footer__states a {
  font-size: 13px;
  color: var(--cow-paper);
  text-decoration: none;
  padding: 4px 0;
}
.cow-footer__states a:hover { color: var(--cow-rose-soft); }

.cow-footer__services { list-style: none; padding: 0; }
.cow-footer__services li { margin-bottom: 8px; }
.cow-footer__services a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  color: var(--cow-paper);
  text-decoration: none;
}
.cow-footer__services a::before {
  content: '○';
  color: var(--cow-rose);
}
.cow-footer__services a:hover::before { content: '●'; }
.cow-footer__services a:hover { color: var(--cow-rose-soft); }

.cow-footer__about p {
  font-size: 14px;
  color: var(--cow-paper);
  opacity: 0.78;
  line-height: 1.7;
  margin-bottom: 12px;
}
.cow-footer__about a { color: var(--cow-rose-soft); }

.cow-footer__bottom {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.18);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cow-paper);
  opacity: 0.7;
}
.cow-footer__bottom a { color: var(--cow-paper); text-decoration: underline; text-decoration-color: var(--cow-rose); }

/* ==========================================================================
   Listing page
   ========================================================================== */

.cow-listing-hero { padding: 48px 0 36px; border-bottom: 1px solid var(--cow-ink); }
.cow-listing-hero h1 {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  font-size: clamp(36px, 5.5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.015em;
  margin: 14px 0 12px;
}
.cow-listing-hero p {
  font-size: 16px;
  max-width: 70ch;
  color: var(--cow-ink-soft);
  line-height: 1.65;
}
.cow-listing-hero__strip {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cow-listing-hero__strip span {
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  color: var(--cow-ink);
  padding: 6px 12px;
  border-radius: 100px;
}
.cow-listing-hero__strip span:nth-child(2n) { background: var(--cow-rose); border-color: var(--cow-rose-deep); color: #fff; }
.cow-listing-hero__strip span:nth-child(3n) { background: var(--cow-ink); color: var(--cow-paper); }

.cow-listing { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 36px; padding: 36px 0 88px; }
.cow-filter-rail { position: sticky; top: 100px; align-self: start; }
.cow-filter-rail__group { margin-bottom: 24px; }
.cow-filter-rail__group summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Fraunces', serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--cow-ink);
  padding: 8px 0;
  border-bottom: 1px solid var(--cow-ink);
  margin-bottom: 12px;
}
.cow-filter-rail__group summary::-webkit-details-marker { display: none; }
.cow-filter-rail__group summary::after { content: '+'; font-family: 'Geist Mono', monospace; color: var(--cow-rose); }
.cow-filter-rail__group[open] summary::after { content: '−'; }

.cow-filter-rail__list { display: flex; flex-direction: column; gap: 4px; max-height: 280px; overflow-y: auto; padding-right: 4px; }
.cow-filter-rail__list a {
  font-family: 'Nunito', sans-serif;
  font-size: 13.5px;
  text-decoration: none;
  color: var(--cow-ink-soft);
  padding: 4px 0;
  display: flex;
  justify-content: space-between;
}
.cow-filter-rail__list a:hover { color: var(--cow-rose-deep); }
.cow-filter-rail__list a[data-on="1"] {
  font-weight: 700;
  color: var(--cow-rose-deep);
  border-left: 3px solid var(--cow-rose);
  padding-left: 8px;
  margin-left: -8px;
}
.cow-filter-rail__list a span {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--cow-ink-fade);
}

.cow-results { display: flex; flex-direction: column; gap: 14px; }
.cow-results__head {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  align-items: baseline;
  padding-bottom: 14px;
  border-bottom: 1.5px solid var(--cow-ink);
}
.cow-results__head h2 {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.cow-results__head .cow-mono { color: var(--cow-ink-fade); font-size: 12px; }

.cow-result-card {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr) auto;
  gap: 22px;
  padding: 18px;
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  text-decoration: none;
  color: var(--cow-ink);
  transition: box-shadow 0.16s ease, transform 0.16s ease;
}
.cow-result-card:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 0 var(--cow-rose); }
.cow-result-card__thumb {
  aspect-ratio: 5/4;
  background-size: cover;
  background-position: center;
  background-color: var(--cow-paper-deep);
  border: 1px solid var(--cow-ink);
  border-radius: 6px;
}
.cow-result-card__body { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.cow-result-card__name {
  font-family: 'Fraunces', serif;
  font-size: 21px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.05;
}
.cow-result-card__loc {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--cow-ink-fade);
  text-transform: uppercase;
}
.cow-result-card__caps {
  font-size: 13.5px;
  color: var(--cow-ink-soft);
  line-height: 1.45;
}
.cow-result-card__chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: auto; padding-top: 6px; }
.cow-result-card__chips span {
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  background: var(--cow-paper);
  border: 1px solid var(--cow-rule);
  color: var(--cow-ink-soft);
  padding: 3px 8px;
  border-radius: 100px;
}
.cow-result-card[data-thin="1"] {
  background: var(--cow-paper);
  border-style: dashed;
}
.cow-result-card__action {
  align-self: center;
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--cow-rose-deep);
  white-space: nowrap;
}

.cow-pagination {
  margin-top: 28px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
}
.cow-pagination a, .cow-pagination span {
  padding: 8px 16px;
  border: 1px solid var(--cow-ink);
  border-radius: 100px;
  text-decoration: none;
  color: var(--cow-ink);
}
.cow-pagination a:hover { background: var(--cow-rose-soft); }
.cow-pagination span { background: var(--cow-ink); color: var(--cow-paper); }

/* ==========================================================================
   Home page
   ========================================================================== */

.cow-home-hero {
  padding: 72px 0 56px;
  border-bottom: 1px solid var(--cow-ink);
  background:
    radial-gradient(ellipse at top right, rgba(196, 119, 138, 0.12), transparent 60%),
    radial-gradient(ellipse at bottom left, rgba(122, 141, 110, 0.1), transparent 50%);
}
.cow-home-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 56px;
  align-items: stretch;
}
.cow-home-hero h1 {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
  font-size: clamp(48px, 7.5vw, 96px);
  line-height: 1.0;
  letter-spacing: -0.02em;
  margin: 18px 0 22px;
  color: var(--cow-ink);
}
.cow-home-hero h1 em {
  font-style: italic;
  color: var(--cow-rose-deep);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.cow-home-hero p {
  font-size: 17px;
  max-width: 56ch;
  color: var(--cow-ink-soft);
  line-height: 1.7;
  margin-bottom: 22px;
}
.cow-home-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }

.cow-home-hero__board {
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  padding: 26px;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.cow-home-hero__board::before {
  content: '';
  position: absolute;
  inset: 10px;
  border: 1px dashed var(--cow-rule);
  pointer-events: none;
  border-radius: 4px;
}
.cow-home-hero__board h3 {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
  margin-bottom: 18px;
}
.cow-home-hero__board ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 0; flex: 1; }
.cow-home-hero__board li {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--cow-rule-soft);
  font-size: 14px;
  align-items: center;
  flex: 1;
}
.cow-home-hero__board li:last-child { border-bottom: 0; }
.cow-home-hero__board li strong {
  font-family: 'Fraunces', serif;
  font-size: 20px;
  color: var(--cow-rose-deep);
  font-weight: 700;
}
.cow-home-hero__board li span:nth-child(2) {
  font-family: 'Fraunces', serif;
  font-size: 16px;
  font-weight: 500;
  color: var(--cow-ink);
}
.cow-home-hero__board li span:nth-child(3) {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--cow-ink-fade);
  letter-spacing: 0.04em;
}

.cow-home-strip { padding: 36px 0; border-bottom: 1px solid var(--cow-ink); background: var(--cow-paper-warm); }
.cow-home-strip__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 32px; }
.cow-home-strip__cell { display: flex; flex-direction: column; gap: 6px; }
.cow-home-strip__cell strong {
  font-family: 'Fraunces', serif;
  font-size: 56px;
  font-weight: 600;
  line-height: 1;
  color: var(--cow-rose-deep);
  font-variation-settings: 'opsz' 144;
  letter-spacing: -0.01em;
}
.cow-home-strip__cell span {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cow-ink-fade);
}

.cow-section-block { padding: 64px 0; border-bottom: 1px solid var(--cow-rule-soft); }
.cow-section-block:last-of-type { border-bottom: 0; }
.cow-section-block__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 32px;
}
.cow-section-block__head h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.05;
}
.cow-section-block__head a {
  font-family: 'Geist Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cow-rose-deep);
}

.cow-state-board { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; }
.cow-state-board a {
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  color: var(--cow-ink);
  padding: 10px 14px;
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.cow-state-board a:hover { background: var(--cow-rose-soft); border-color: var(--cow-rose-deep); }
.cow-state-board a span {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  color: var(--cow-ink-fade);
  font-weight: 500;
}

.cow-service-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.cow-service-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px;
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  text-decoration: none;
  color: var(--cow-ink);
  position: relative;
}
.cow-service-card::before {
  content: attr(data-no);
  position: absolute;
  top: -2px;
  right: 16px;
  background: var(--cow-rose);
  color: #fff;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  border-radius: 0 0 6px 6px;
}
.cow-service-card:hover { background: var(--cow-rose-soft); border-color: var(--cow-rose-deep); }
.cow-service-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.005em;
  margin-top: 18px;
}
.cow-service-card p { font-size: 14px; color: var(--cow-ink-soft); line-height: 1.55; }

/* Static page shell */
.cow-static {
  padding: 56px 0 88px;
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 2fr);
  gap: 56px;
  align-items: start;
}
.cow-static__sidebar {
  position: sticky; top: 100px;
  align-self: start;
  border: 1px solid var(--cow-ink);
  background: var(--cow-paper-warm);
  border-radius: 8px;
  padding: 22px;
}
.cow-static__sidebar dt {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--cow-ink-fade);
  text-transform: uppercase;
  margin-top: 12px;
}
.cow-static__sidebar dt:first-child { margin-top: 0; }
.cow-static__sidebar dd { font-size: 14px; color: var(--cow-ink); line-height: 1.5; margin-top: 4px; }
.cow-static__main h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(38px, 5.5vw, 64px);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.02;
  margin-bottom: 24px;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.cow-static__main h2 {
  font-family: 'Fraunces', serif;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.005em;
  margin: 32px 0 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--cow-ink);
  font-variation-settings: 'opsz' 60;
}
.cow-static__main p { font-size: 16px; line-height: 1.7; color: var(--cow-ink-soft); margin-bottom: 14px; }

/* Blog */
.cow-blog-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.cow-blog-card {
  display: flex;
  flex-direction: column;
  background: var(--cow-paper-warm);
  border: 1px solid var(--cow-ink);
  border-radius: 8px;
  text-decoration: none;
  color: var(--cow-ink);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
  overflow: hidden;
}
.cow-blog-card:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 0 var(--cow-rose); }
.cow-blog-card__cover { aspect-ratio: 16/9; background-size: cover; background-position: center; background-color: var(--cow-paper-deep); }
.cow-blog-card__body { padding: 18px 20px 22px; }
.cow-blog-card__cat {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--cow-rose-deep);
  text-transform: uppercase;
}
.cow-blog-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.005em;
  margin: 8px 0 10px;
  line-height: 1.1;
}
.cow-blog-card p { font-size: 13.5px; color: var(--cow-ink-soft); line-height: 1.55; }

.cow-blog-detail { padding: 56px 0 88px; display: grid; grid-template-columns: minmax(0, 2fr) 320px; gap: 48px; align-items: start; }
.cow-blog-detail h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(38px, 5.5vw, 56px);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.02;
  margin-bottom: 24px;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.cow-blog-detail__cover { aspect-ratio: 16/8; background-size: cover; background-position: center; border: 1px solid var(--cow-ink); border-radius: 8px; margin-bottom: 32px; }
.cow-blog-detail__body p { font-size: 17px; line-height: 1.7; color: var(--cow-ink-soft); margin-bottom: 16px; }
.cow-blog-detail__body h2 { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 600; margin: 32px 0 14px; font-variation-settings: 'opsz' 60; }
.cow-blog-detail__body h3 { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 600; margin: 24px 0 10px; font-variation-settings: 'opsz' 30; }
.cow-blog-detail__body ul, .cow-blog-detail__body ol { padding-left: 24px; margin-bottom: 16px; }
.cow-blog-detail__body li { font-size: 16px; line-height: 1.65; color: var(--cow-ink-soft); margin-bottom: 6px; }

/* 404 */
.cow-404 {
  padding: 88px 0;
  text-align: center;
}
.cow-404 .cow-eyebrow { color: var(--cow-rose-deep); }
.cow-404 h1 {
  font-family: 'Fraunces', serif;
  font-size: clamp(64px, 12vw, 144px);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 20px 0;
  font-variation-settings: 'opsz' 144, 'SOFT' 100;
}
.cow-404 h1 strong { color: var(--cow-rose); }
.cow-404 p { font-size: 17px; max-width: 56ch; margin: 0 auto 24px; color: var(--cow-ink-soft); line-height: 1.7; }

/* ==========================================================================
   Mobile responsive
   ========================================================================== */

@media (max-width: 1080px) {
  .cow-detail { grid-template-columns: minmax(0, 1fr); gap: 28px; }
  .cow-aside-stack { position: static; }
  .cow-listing { grid-template-columns: minmax(0, 1fr); }
  .cow-filter-rail { position: static; }
  .cow-filter-rail__list { max-height: none; }
  .cow-needs { grid-template-columns: minmax(0, 1fr); }
  .cow-lanes { grid-template-columns: minmax(0, 1fr); }
  .cow-where { grid-template-columns: minmax(0, 1fr); }
  .cow-home-hero__grid { grid-template-columns: minmax(0, 1fr); gap: 32px; }
  .cow-state-board { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .cow-service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cow-blog-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cow-blog-detail { grid-template-columns: minmax(0, 1fr); }
  .cow-static { grid-template-columns: minmax(0, 1fr); }
  .cow-static__sidebar { position: static; }
  .cow-footer__grid { grid-template-columns: minmax(0, 1fr); gap: 36px; }
  .cow-photobay { grid-template-columns: 2fr 1fr; }
  .cow-photobay__cell--lead { grid-row: auto; aspect-ratio: 16/9; grid-column: span 2; }
  .cow-nearby { grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 760px) {
  .cow-shell { width: calc(100% - 32px); }
  .cow-nav { display: none; }
  .cow-burger { display: flex; }
  .cow-header__strip { font-size: 9px; letter-spacing: 0.14em; }
  .cow-header__strip-row span:nth-child(2) { display: none; }
  .cow-cover { padding: 30px 22px 28px; }
  .cow-cover__name { font-size: clamp(32px, 9vw, 50px); }
  .cow-photobay { grid-template-columns: minmax(0, 1fr); }
  .cow-photobay__cell--lead { aspect-ratio: 4/3; grid-column: auto; }
  .cow-section__head { grid-template-columns: minmax(0, 1fr); padding: 12px 18px; }
  .cow-section__sub { justify-self: start; }
  .cow-section__body, .cow-needs, .cow-where, .cow-ledger, .cow-attribution, .cow-lanes, .cow-stateblock, .cow-diy, .cow-faq, .cow-nearby { padding: 22px 18px; }
  .cow-attribution { overflow-x: auto; }
  .cow-attribution table { min-width: 460px; }
  .cow-diy__row { grid-template-columns: minmax(0, 1fr); gap: 4px; padding: 10px 14px; }
  .cow-state-board { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cow-service-grid { grid-template-columns: minmax(0, 1fr); }
  .cow-blog-list { grid-template-columns: minmax(0, 1fr); }
  .cow-result-card { grid-template-columns: 100px minmax(0, 1fr); }
  .cow-result-card__action { display: none; }
  .cow-home-strip__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
  .cow-home-strip__cell strong { font-size: 38px; }
  .cow-home-hero h1 { font-size: clamp(38px, 11vw, 60px); }
  .cow-listing-hero h1 { font-size: clamp(32px, 9vw, 48px); }
  .cow-section-block__head h2 { font-size: 26px; }
  .cow-footer { padding: 48px 0 24px; }
  .cow-footer__states { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cow-blog-detail__body p { font-size: 16px; }
}

@media print {
  body::before { display: none; }
  .cow-header, .cow-footer, .cow-aside, .cow-burger, .cow-drawer, .cow-drawer-backdrop { display: none !important; }
  .cow-detail { grid-template-columns: minmax(0, 1fr); }
}
