/* FedOps — The Funding Register
   Aesthetic: modern Federal Register. Warm paper, ledger rules, stamp chips,
   dollar-green money, mono numerals. Fraunces / Libre Franklin / IBM Plex Mono. */

:root {
  --paper: #f6f4ee;
  --paper-deep: #efece3;
  --card: #fbfaf6;
  --ink: #191c19;
  --ink-soft: #4c5350;
  --ink-faint: #8a9089;
  --rule: #d9d4c6;
  --rule-dark: #b9b2a0;
  --green: #1e6b4f;
  --green-bright: #279968;
  --green-wash: #e4efe7;
  --red: #b3372b;
  --red-wash: #f7e8e5;
  --amber: #9a7b22;
  --amber-wash: #f5eed8;
  --blue: #2b5d8a;
  --serif: "Fraunces", Georgia, serif;
  --sans: "Libre Franklin", "Franklin Gothic Medium", sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scrollbar-gutter: stable; }
body {
  font-family: var(--sans); color: var(--ink); background: var(--paper);
  background-image: radial-gradient(rgba(25,28,25,.028) 1px, transparent 1px);
  background-size: 22px 22px;
  font-size: 14px; line-height: 1.45;
}
button { font: inherit; cursor: pointer; }
input, select { font: inherit; }

/* ---------------------------------------------------------------- masthead */
.masthead { border-bottom: 3px double var(--rule-dark); background: var(--paper); }
.masthead-rule { height: 6px; background: var(--green); }
.masthead-inner {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 24px; padding: 18px 28px 10px; max-width: 1480px; margin: 0 auto;
}
.brand { display: flex; align-items: baseline; gap: 12px; }
.brand-seal { color: var(--green); font-size: 18px; transform: translateY(-2px); }
.brand h1 { font-family: var(--serif); font-weight: 700; font-size: 27px; letter-spacing: -.5px; }
.brand-domain { color: var(--green); }
.brand-sub {
  font-family: var(--serif); font-style: italic; font-size: 15px; color: var(--ink-soft);
  border-left: 1px solid var(--rule-dark); padding-left: 12px;
}
.ticker {
  font-family: var(--mono); font-size: 12px; color: var(--ink-soft);
  display: flex; align-items: center; gap: 8px; white-space: nowrap; overflow: hidden;
}
.tick-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--ink-faint);
  flex: none;
}
.tick-dot.live { background: var(--green-bright); animation: pulse 2.2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(39,153,104,.45);} 55% { box-shadow: 0 0 0 7px rgba(39,153,104,0);} }

.tabs {
  display: flex; align-items: center; gap: 4px; padding: 0 28px;
  max-width: 1480px; margin: 0 auto;
}
.tab {
  border: none; background: none; padding: 10px 16px 12px; font-weight: 600;
  font-size: 13.5px; color: var(--ink-soft); border-bottom: 3px solid transparent;
  letter-spacing: .2px;
}
.tab:hover { color: var(--ink); }
.tab.active { color: var(--green); border-bottom-color: var(--green); }
.tabs-annot { margin-left: auto; font-size: 10.5px; color: var(--ink-faint); letter-spacing: 1px; }
.mono { font-family: var(--mono); }

/* ---------------------------------------------------------------- layout */
.view { display: none; max-width: 1480px; margin: 0 auto; padding: 24px 28px 80px; }
.view.active { display: block; }
#view-register.active { display: grid; grid-template-columns: 252px 1fr; gap: 32px; }

/* rail */
.rail-block { padding: 14px 0; border-bottom: 1px dotted var(--rule-dark); }
.rail-block:first-child { padding-top: 2px; }
.rail-label {
  display: block; font-size: 10.5px; font-weight: 700; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--ink-faint); margin-bottom: 8px;
}
.input {
  width: 100%; padding: 8px 10px; border: 1px solid var(--rule-dark);
  background: var(--card); border-radius: 3px; color: var(--ink); font-size: 13.5px;
}
.input:focus { outline: 2px solid var(--green); outline-offset: -1px; }
.select.slim { width: auto; padding: 5px 8px; }
.chip-row { display: flex; gap: 6px; flex-wrap: wrap; }
.chip {
  border: 1px solid var(--rule-dark); background: var(--card); border-radius: 999px;
  padding: 4px 12px; font-size: 12.5px; font-weight: 600; color: var(--ink-soft);
}
.chip.active { background: var(--green); border-color: var(--green); color: #fff; }
.check { display: flex; gap: 8px; align-items: center; padding: 4px 0; font-size: 13px; color: var(--ink-soft); }
.facet-list { display: flex; flex-direction: column; max-height: 200px; overflow: auto; }
.facet-item {
  display: flex; justify-content: space-between; gap: 6px; padding: 4px 6px;
  font-size: 12.5px; color: var(--ink-soft); border-radius: 3px; border: none;
  background: none; text-align: left; width: 100%;
}
.facet-item:hover { background: var(--paper-deep); }
.facet-item.active { background: var(--green-wash); color: var(--green); font-weight: 600; }
.facet-n { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); }

/* feed */
.feed-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.feed-count { font-size: 12px; color: var(--ink-soft); letter-spacing: .5px; }
.sorter { display: flex; align-items: center; gap: 10px; }
.sorter .rail-label { margin: 0; }

.cards { display: flex; flex-direction: column; gap: 14px; }
.card {
  background: var(--card); border: 1px solid var(--rule);
  border-left: 4px solid var(--rule-dark); border-radius: 4px;
  padding: 16px 20px 14px; position: relative;
  animation: rise .35s ease both;
  transition: border-color .15s, box-shadow .15s;
}
.cards .card:nth-child(2) { animation-delay: .04s; }
.cards .card:nth-child(3) { animation-delay: .08s; }
.cards .card:nth-child(4) { animation-delay: .12s; }
.cards .card:nth-child(5) { animation-delay: .16s; }
@keyframes rise { from { opacity: 0; transform: translateY(7px);} to { opacity: 1; transform: none;} }
.card:hover { border-left-color: var(--green); box-shadow: 0 3px 14px rgba(25,28,25,.07); }
.card.has-ai { border-left-color: var(--green); }
.card.is-stale { border-left-color: var(--amber); }

.card-eyebrow {
  display: flex; gap: 10px; align-items: center; font-size: 11px;
  color: var(--ink-faint); margin-bottom: 6px; font-family: var(--mono);
}
.card-eyebrow .agency { color: var(--blue); font-weight: 600; font-family: var(--sans); font-size: 11.5px; letter-spacing: .4px; text-transform: uppercase; }
.card-title {
  font-family: var(--serif); font-size: 18.5px; font-weight: 600; line-height: 1.25;
  margin-bottom: 7px; cursor: pointer;
}
.card-title:hover { color: var(--green); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.card-summary { color: var(--ink-soft); font-size: 13.5px; max-width: 72ch; margin-bottom: 10px; }
.card-summary.placeholder { font-style: italic; color: var(--ink-faint); }

.stamp-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.stamp {
  font-size: 10.5px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 2px; border: 1px solid currentColor;
}
.stamp.green { color: var(--green); background: var(--green-wash); }
.stamp.red { color: var(--red); background: var(--red-wash); }
.stamp.amber { color: var(--amber); background: var(--amber-wash); }
.stamp.gray { color: var(--ink-soft); background: var(--paper-deep); border-color: var(--rule-dark); }

.card-ledger {
  display: flex; gap: 26px; align-items: center; border-top: 1px dotted var(--rule-dark);
  padding-top: 10px; font-family: var(--mono); font-size: 12.5px;
}
.ledger-item b { display: block; font-size: 10px; font-weight: 700; letter-spacing: 1.2px; color: var(--ink-faint); font-family: var(--sans); text-transform: uppercase; }
.ledger-item span { color: var(--ink); font-weight: 500; }
.ledger-item .money { color: var(--green); font-weight: 600; }
.ledger-item .urgent { color: var(--red); font-weight: 600; }
.card-actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.crm-select {
  padding: 4px 8px; border: 1px solid var(--rule-dark); border-radius: 3px;
  background: var(--paper); font-size: 12px; font-weight: 600; color: var(--ink-soft);
}
.crm-select.set { border-color: var(--green); color: var(--green); background: var(--green-wash); }
.gov-link {
  font-size: 12px; font-weight: 600; color: var(--blue); text-decoration: none;
  border-bottom: 1px dotted var(--blue);
}
.more-btn {
  margin: 22px auto 0; display: block; background: none; border: 1px solid var(--rule-dark);
  border-radius: 3px; padding: 9px 22px; font-weight: 600; color: var(--ink-soft);
}
.more-btn:hover { border-color: var(--green); color: var(--green); }

/* assistant CTA on matches */
.asst-cta {
  display: flex; gap: 14px; align-items: center;
  background: var(--green-wash); border: 1px solid var(--green);
  border-radius: 5px; padding: 13px 18px; margin-bottom: 18px; font-size: 13.5px;
}
.asst-cta-dot { font-size: 22px; }
.asst-cta b { display: block; }

/* ---------------------------------------------------------------- board */
.board { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.lane { background: var(--paper-deep); border-radius: 5px; padding: 10px; min-height: 320px; }
.lane h3 {
  font-size: 11px; letter-spacing: 1.4px; text-transform: uppercase; color: var(--ink-soft);
  padding: 2px 4px 10px; display: flex; justify-content: space-between;
}
.lane h3 .mono { color: var(--ink-faint); }
.lane-drop { min-height: 60px; }
.lane.dragover { outline: 2px dashed var(--green); outline-offset: -4px; background: var(--green-wash); }
.lane-card {
  background: var(--card); border: 1px solid var(--rule); border-radius: 4px;
  padding: 10px 12px; margin-bottom: 8px; font-size: 12.5px; cursor: grab;
}
.lane-card:hover { border-color: var(--green); }
.lane-card.dragging { opacity: .45; cursor: grabbing; transform: rotate(1.5deg); }
.lane-card .t { font-weight: 600; line-height: 1.3; margin-bottom: 5px; }
.lane-card .m { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); }
.lane-card .m .money { color: var(--green); }

/* ---------------------------------------------------------------- changes */
.register-col { max-width: 860px; }
.col-title { font-family: var(--serif); font-size: 24px; font-weight: 600; margin-bottom: 6px; }
.col-sub { color: var(--ink-soft); margin-bottom: 22px; max-width: 64ch; }
.changes-feed { border-top: 3px double var(--rule-dark); }
.change-row {
  display: grid; grid-template-columns: 150px 1fr; gap: 18px; padding: 13px 4px;
  border-bottom: 1px dotted var(--rule-dark); animation: rise .3s ease both;
}
.change-when { font-family: var(--mono); font-size: 11.5px; color: var(--ink-faint); padding-top: 2px; }
.change-title { font-weight: 600; margin-bottom: 3px; cursor: pointer; }
.change-title:hover { color: var(--green); }
.change-diff { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }
.change-diff .f { color: var(--blue); font-weight: 600; }
.change-diff .old { color: var(--red); text-decoration: line-through; }
.change-diff .new { color: var(--green); font-weight: 600; }
.empty-note { padding: 30px 4px; color: var(--ink-faint); font-style: italic; font-family: var(--serif); font-size: 16px; }

/* ---------------------------------------------------------------- drawer */
.drawer-veil {
  position: fixed; inset: 0; background: rgba(25,28,25,.34); opacity: 0;
  pointer-events: none; transition: opacity .22s; z-index: 40;
}
.drawer-veil.open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(620px, 94vw);
  background: var(--paper); border-left: 3px double var(--rule-dark);
  transform: translateX(102%); transition: transform .26s cubic-bezier(.3,.8,.3,1);
  z-index: 50; overflow-y: auto;
}
.drawer.open { transform: none; }
.drawer-inner { padding: 26px 30px 60px; }
.d-eyebrow { font-family: var(--mono); font-size: 11px; color: var(--ink-faint); margin-bottom: 8px; display: flex; justify-content: space-between; gap: 10px; }
.d-close { background: none; border: none; font-size: 20px; color: var(--ink-faint); }
.d-title { font-family: var(--serif); font-size: 24px; font-weight: 700; line-height: 1.2; margin-bottom: 4px; }
.d-agency { color: var(--blue); font-weight: 600; font-size: 12.5px; text-transform: uppercase; letter-spacing: .6px; margin-bottom: 16px; }
.d-summary {
  font-family: var(--serif); font-size: 15.5px; line-height: 1.5; color: var(--ink);
  border-left: 3px solid var(--green); background: var(--green-wash);
  padding: 14px 16px; border-radius: 0 4px 4px 0; margin-bottom: 20px;
}
.d-section { margin-bottom: 20px; }
.d-section h4 {
  font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase; color: var(--ink-faint);
  border-bottom: 1px solid var(--rule); padding-bottom: 4px; margin-bottom: 8px;
}
.d-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 18px; }
.d-kv b { display: block; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-faint); }
.d-kv span { font-family: var(--mono); font-size: 13px; }
.d-kv .money { color: var(--green); font-weight: 600; }
.d-list { padding-left: 18px; color: var(--ink-soft); font-size: 13.5px; }
.d-list li { margin-bottom: 3px; }
.d-list.red li::marker { color: var(--red); }
.d-actions { display: flex; gap: 10px; margin: 18px 0 8px; }
.btn {
  padding: 9px 16px; border-radius: 3px; font-weight: 700; font-size: 13px;
  border: 1px solid var(--green); text-decoration: none; display: inline-block;
}
.btn.primary { background: var(--green); color: #fff; }
.btn.primary:hover { background: var(--green-bright); }
.btn.ghost { color: var(--green); background: none; }
.d-changes { font-family: var(--mono); font-size: 11.5px; color: var(--ink-soft); }
.d-changes div { padding: 4px 0; border-bottom: 1px dotted var(--rule); }

@media (max-width: 1100px) {
  #view-register.active { grid-template-columns: 1fr; }
  .board { grid-template-columns: repeat(2, 1fr); }
}

/* ================================================================ v2 */
.screen[hidden] { display: none !important; }

/* gate (auth + paywall) */
#screen-auth, #screen-paywall, #screen-onboard {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 40px 20px;
}
.gate-card, .onboard-card {
  background: var(--card); border: 1px solid var(--rule-dark); border-top: 6px solid var(--green);
  border-radius: 6px; padding: 38px 42px; width: 420px; max-width: 96vw;
  box-shadow: 0 18px 60px rgba(25,28,25,.12);
  animation: rise .4s ease both;
}
.onboard-card { width: 720px; }
.gate-seal { color: var(--green); font-size: 26px; margin-bottom: 6px; }
.gate-title { font-family: var(--serif); font-size: 30px; font-weight: 700; margin-bottom: 6px; }
.gate-sub { color: var(--ink-soft); margin-bottom: 22px; font-size: 13.5px; }
.gate-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--rule); margin-bottom: 18px; }
.gate-tab { background: none; border: none; padding: 8px 14px; font-weight: 700; color: var(--ink-faint); border-bottom: 3px solid transparent; margin-bottom: -2px; }
.gate-tab.active { color: var(--green); border-bottom-color: var(--green); }
.gate-form { display: flex; flex-direction: column; gap: 12px; }
.gate-err { color: var(--red); font-size: 12.5px; min-height: 16px; }
.btn.wide { width: 100%; text-align: center; border-radius: 4px; padding: 11px; font-size: 14px; }
.linkish { background: none; border: none; color: var(--ink-faint); font-size: 12px; text-decoration: underline dotted; padding: 6px 0 0; }
.linkish:hover { color: var(--green); }

/* onboarding */
.profile-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; margin-top: 18px; }
.pf-field b { display: block; font-size: 10.5px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 6px; }
.span2 { grid-column: span 2; }
textarea.input { resize: vertical; font-family: var(--sans); }
#focusChips .chip { margin: 0 0 4px; }

/* paywall */
.pay-card { width: 460px; text-align: center; }
.plan-box { border: 1px solid var(--rule-dark); border-radius: 5px; padding: 22px; margin-top: 8px; background: var(--paper); }
.plan-name { font-family: var(--serif); font-size: 19px; font-weight: 600; }
.plan-price { font-size: 38px; font-weight: 700; color: var(--green); margin: 6px 0 14px; }
.plan-price .mono { font-size: 38px; }
.plan-per { font-size: 14px; color: var(--ink-faint); font-weight: 500; }
.plan-list { text-align: left; margin-bottom: 18px; }

/* matches */
.wide-col { max-width: 1000px; }
.match-ring { position: absolute; top: 14px; right: 18px; width: 52px; text-align: center; }
.match-ring svg { width: 44px; height: 44px; transform: rotate(-90deg); }
.match-ring .rb { fill: none; stroke: var(--rule); stroke-width: 4; }
.match-ring .rf { fill: none; stroke: var(--green-bright); stroke-width: 4; stroke-linecap: round; transition: stroke-dasharray .6s ease; }
.match-ring .mono { display: block; font-size: 11px; font-weight: 600; color: var(--green); margin-top: -32px; }
.match-reasons { display: flex; flex-wrap: wrap; gap: 4px 14px; margin: -4px 0 10px; }
.match-reasons span { font-size: 12px; color: var(--green); font-weight: 600; }
#matchCards .card { padding-right: 86px; }

/* admin */
.admin-tiles { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; margin: 16px 0 26px; }
.tile { background: var(--card); border: 1px solid var(--rule); border-radius: 4px; padding: 12px 14px; }
.tile b { display: block; font-size: 10px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--ink-faint); margin-bottom: 4px; }
.tile .mono { font-size: 20px; font-weight: 600; color: var(--ink); }
.admin-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 30px; }
.d-sec-title { font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase; color: var(--ink-faint); border-bottom: 1px solid var(--rule); padding-bottom: 4px; margin: 18px 0 10px; }
.admin-table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.admin-table th { text-align: left; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-faint); padding: 6px 8px; border-bottom: 1px solid var(--rule-dark); }
.admin-table td { padding: 7px 8px; border-bottom: 1px dotted var(--rule); }
.admin-table .small { font-size: 10.5px; color: var(--ink-faint); }
.ev-summary { display: flex; flex-direction: column; }
.ev-row { display: flex; justify-content: space-between; padding: 6px 4px; border-bottom: 1px dotted var(--rule); font-size: 13px; }
.ev-feed { max-height: 420px; overflow: auto; }
.ev-item { font-size: 11px; color: var(--ink-soft); padding: 4px 0; border-bottom: 1px dotted var(--rule); }
.ev-item i { color: var(--ink-faint); }

@media (max-width: 900px) {
  .admin-grid, .profile-grid { grid-template-columns: 1fr; }
  .span2 { grid-column: span 1; }
  .admin-tiles { grid-template-columns: repeat(3, 1fr); }
}
