/* River Forest Directory — dark navy theme */
:root {
  /* Page chrome */
  --bg:#162840;
  --bg-deep:#0f1d31;
  --bg-tint:#1d3354;
  --card:#243d62;
  --card-alt:#2a4470;
  --card-elev:#2d4a78;
  --card-shadow: 0 1px 2px rgba(0,0,0,.25), 0 4px 12px rgba(0,0,0,.22);
  --card-shadow-strong: 0 2px 4px rgba(0,0,0,.30), 0 10px 22px rgba(0,0,0,.30);

  /* Lines & ink */
  --line:#3a567f;
  --line-strong:#506e9a;
  --ink:#ffffff;
  --ink-soft:#dde5f0;
  --muted:#9ab0c9;

  /* Brand accent (brightened forest green for dark bg) */
  --accent:#5cb87a;
  --accent-hover:#7dca96;
  --accent-tint:rgba(92,184,122,.16);
  --accent-tint-2:rgba(92,184,122,.30);
  --accent-deep:#1f5c3f;

  /* Secondary palette */
  --gold:#d9a85a;
  --gold-tint:rgba(217,168,90,.16);
  --warn:#e57878;
  --warn-deep:#9b2c2c;
  --warn-tint:rgba(229,120,120,.16);
  --hl:rgba(255,243,176,.18);

  /* Section colors (brighter, designed for dark cards) */
  --c-address:#9aa9bd;        --c-address-tint:rgba(154,169,189,.14);
  --c-residents:#5cb87a;      --c-residents-tint:rgba(92,184,122,.14);
  --c-pets:#d99a52;           --c-pets-tint:rgba(217,154,82,.16);
  --c-payments:#6ca6e0;       --c-payments-tint:rgba(108,166,224,.16);
  --c-interests:#b48cd9;      --c-interests-tint:rgba(180,140,217,.16);
  --c-danger:#e57878;         --c-danger-tint:rgba(229,120,120,.16);

  --radius:8px;
  --radius-sm:5px;
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin:0;
  font-family: -apple-system, "Segoe UI", system-ui, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  background-image:
    radial-gradient(1300px 700px at 0% -10%, rgba(108,166,224,.10), transparent 60%),
    radial-gradient(900px 600px at 100% 0%, rgba(92,184,122,.06), transparent 55%),
    linear-gradient(180deg, #182d4a 0%, var(--bg) 350px);
  color: var(--ink);
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); text-decoration: underline; text-underline-offset: 2px; }

/* ---------- Top bar ---------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(15,29,49,.85);
  backdrop-filter: saturate(160%) blur(10px);
  -webkit-backdrop-filter: saturate(160%) blur(10px);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 rgba(0,0,0,.15), 0 8px 18px -12px rgba(0,0,0,.55);
  padding: .55rem 1.25rem;
  display: flex;
  align-items: baseline;
  gap: 1.25rem;
  flex-wrap: wrap;
  color: var(--ink);
}
.topbar h1 { font-size: 1.05rem; margin: 0; letter-spacing: .005em; font-weight: 650; }
.topbar h1 a { color: #ffffff; display: inline-flex; align-items: baseline; gap: .45rem; }
.topbar h1 a::before {
  content: "";
  display: inline-block;
  width: .55rem;
  height: .55rem;
  border-radius: 2px;
  background: var(--accent);
  transform: translateY(-.05em);
  box-shadow: 0 0 0 3px var(--accent-tint);
}
.topbar h1 a:hover { text-decoration: none; color: var(--accent); }
.topbar nav { display: flex; flex-wrap: wrap; gap: .15rem; }
.topbar nav a {
  font-size: .92rem;
  color: var(--ink-soft);
  padding: .35rem .65rem;
  border-radius: var(--radius-sm);
  margin: 0;
  transition: background-color .12s ease, color .12s ease;
}
.topbar nav a:hover {
  background: var(--accent-tint);
  color: var(--accent);
  text-decoration: none;
}
.topbar nav a.active {
  background: var(--accent);
  color: #0e1a2b;
  font-weight: 600;
}
.topbar nav a.active:hover { background: var(--accent-hover); color: #0e1a2b; }

.context-strip {
  flex-basis: 100%;
  padding: .45rem .15rem 0;
  font-size: .85rem;
  color: var(--ink-soft);
  border-top: 1px dashed var(--line);
  margin-top: .35rem;
}
.context-strip a { color: #ffffff; font-weight: 500; }
.context-strip .muted, .context-strip a.muted { font-weight: 400; color: var(--muted); }
.context-strip a:hover { color: var(--accent); }

/* "Signed in as <email> [role] sign out" chip in the top bar */
.user-chip {
  flex-basis: 100%;
  padding: .35rem .15rem 0;
  font-size: .82rem;
  color: var(--ink-soft);
  border-top: 1px dashed var(--line);
  margin-top: .35rem;
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
}
.user-chip strong { color: #fff; font-weight: 600; }
.user-chip .muted { color: var(--muted); }
.user-chip button.muted:hover { color: var(--accent); }

/* ---------- Layout ---------- */
main { padding: 1.25rem 1rem 2.5rem; max-width: 1200px; margin: 0 auto; color: var(--ink); }

/* ---------- Flash messages ---------- */
.flash { list-style:none; padding:0; margin: 0 0 1rem; }
.flash li {
  padding: .65rem .9rem;
  margin-bottom: .5rem;
  border-radius: var(--radius-sm);
  background: var(--accent-tint);
  color: var(--accent-hover);
  border: 1px solid var(--accent-tint-2);
  font-size: .92rem;
}
.flash li.error, .flash li.warning {
  background: var(--warn-tint);
  color: var(--warn);
  border-color: rgba(229,120,120,.35);
}

/* ---------- Cards ---------- */
.card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.1rem 1.2rem;
  margin-bottom: 1rem;
  box-shadow: var(--card-shadow);
  color: var(--ink);
}
.card h2 {
  margin: 0 0 .75rem;
  font-size: 1.05rem;
  font-weight: 650;
  letter-spacing: .005em;
  color: #ffffff;
}
.card h3 {
  font-size: .82rem;
  margin: 1rem 0 .5rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
}
.card h3:first-child { margin-top: 0; }
.card p { color: var(--ink-soft); }
.muted { color: var(--muted); font-size: .9rem; }

/* ---------- Section-coded cards (used on edit-parcel page) ---------- */
.card.section-address   { --section-color: var(--c-address);   --section-tint: var(--c-address-tint); }
.card.section-residents { --section-color: var(--c-residents); --section-tint: var(--c-residents-tint); }
.card.section-pets      { --section-color: var(--c-pets);      --section-tint: var(--c-pets-tint); }
.card.section-payments  { --section-color: var(--c-payments);  --section-tint: var(--c-payments-tint); }
.card.section-interests { --section-color: var(--c-interests); --section-tint: var(--c-interests-tint); }
.card.section-danger    { --section-color: var(--c-danger);    --section-tint: var(--c-danger-tint); }

.card[class*="section-"] {
  padding-left: 1.35rem;
  border-left: none;
}
.card[class*="section-"]::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  background: var(--section-color);
  border-radius: var(--radius) 0 0 var(--radius);
  box-shadow: 0 0 14px -2px var(--section-color);
}
.card[class*="section-"] > h2:first-of-type {
  color: var(--section-color);
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--line);
  margin-bottom: .85rem;
  display: flex;
  align-items: baseline;
  gap: .55rem;
  flex-wrap: wrap;
}
.card[class*="section-"] > h2:first-of-type .muted { font-size: .85rem; font-weight: 400; }

/* ---------- Grid helpers ---------- */
.grid-2 { display:grid; grid-template-columns: 1fr 2fr; gap: 1rem; align-items: start; }
@media (max-width: 900px) { .grid-2 { grid-template-columns: 1fr; } }

/* ---------- Forms ---------- */
.form-row { display:flex; flex-direction:column; gap:.25rem; margin-bottom:.7rem; }
.form-row label {
  font-size: .75rem;
  color: var(--ink-soft);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.form-row label .muted { color: var(--muted); }
.form-row input,
.form-row select,
.form-row textarea {
  padding: .5rem .65rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  font: inherit;
  background: #f4f7fb;
  color: #0e1726;
  transition: border-color .12s ease, box-shadow .12s ease, background-color .12s ease;
}
.form-row input::placeholder,
.form-row textarea::placeholder { color: #6e7d92; }
.form-row input:hover,
.form-row select:hover,
.form-row textarea:hover {
  background: #ffffff;
  border-color: var(--section-color, var(--accent));
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
  outline: none;
  background: #ffffff;
  border-color: var(--section-color, var(--accent));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--section-color, var(--accent)) 28%, transparent);
}
.form-row input[readonly],
.form-row select[disabled],
.form-row input[disabled] {
  background: #d9e0ea;
  color: #4a5874;
  cursor: not-allowed;
  border-color: var(--line);
}
.form-row textarea { min-height: 70px; resize: vertical; }

.row { display:flex; gap:.6rem; flex-wrap: wrap; align-items: flex-end; }
.row > * { flex: 1; }

/* ---------- Buttons ---------- */
.btn {
  padding: .45rem .9rem;
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,.06);
  color: var(--ink);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font: inherit;
  font-weight: 500;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  transition: background-color .12s ease, border-color .12s ease, color .12s ease,
              box-shadow .12s ease, transform .04s ease;
  text-decoration: none;
}
.btn:hover {
  background: rgba(255,255,255,.12);
  border-color: var(--accent);
  color: #ffffff;
  text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-tint-2);
  border-color: var(--accent);
}
.btn.primary {
  background: var(--accent);
  color: #0e1a2b;
  border-color: var(--accent);
  font-weight: 600;
  box-shadow: 0 1px 0 rgba(0,0,0,.20), 0 4px 10px rgba(92,184,122,.22);
}
.btn.primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  color: #0e1a2b;
  box-shadow: 0 1px 0 rgba(0,0,0,.20), 0 6px 14px rgba(125,202,150,.30);
}
.btn.danger {
  background: var(--warn);
  color:#ffffff;
  border-color: var(--warn);
  font-weight: 600;
  box-shadow: 0 1px 0 rgba(0,0,0,.20), 0 4px 10px rgba(229,120,120,.22);
}
.btn.danger:hover {
  background:#ef9090;
  border-color:#ef9090;
  color:#0e1a2b;
}

/* ---------- Lists (search results, etc.) ---------- */
.list {
  list-style: none;
  padding: 0;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  max-height: 60vh;
  overflow: auto;
  background: var(--card);
  box-shadow: var(--card-shadow);
}
.list li {
  padding: .55rem .8rem;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  color: var(--ink);
  transition: background-color .08s ease, color .08s ease;
}
.list li:last-child { border-bottom: none; }
.list li:hover { background: var(--accent-tint); color: #ffffff; }
.list li.empty { color: var(--muted); cursor: default; }
.list li.empty:hover { background: transparent; }

/* ---------- Tables ---------- */
table.data { width: 100%; border-collapse: separate; border-spacing: 0; color: var(--ink); }
table.data thead th {
  text-align: left;
  padding: .55rem .7rem;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink-soft);
  font-weight: 600;
  background: var(--bg-tint);
  border-bottom: 1px solid var(--line-strong);
  border-top: 1px solid var(--line);
  position: sticky;
  top: 0;
}
table.data thead th:first-child { border-top-left-radius: var(--radius-sm); border-left: 1px solid var(--line); }
table.data thead th:last-child  { border-top-right-radius: var(--radius-sm); border-right: 1px solid var(--line); }
table.data tbody td {
  padding: .55rem .7rem;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  color: var(--ink);
}
table.data tbody td a { color: var(--accent); }
table.data tbody td a:hover { color: var(--accent-hover); }
table.data tbody tr { transition: background-color .08s ease; }
table.data tbody tr:nth-child(even) td { background: rgba(255,255,255,.025); }
table.data tbody tr:hover td {
  background: color-mix(in srgb, var(--section-color, var(--accent)) 18%, transparent);
}
table.data tbody tr:last-child td { border-bottom: none; }

.actions { display: flex; gap: .35rem; justify-content: flex-end; align-items: center; }

/* ---------- Tags / pills ---------- */
.tag {
  display: inline-block;
  padding: .1rem .55rem;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  font-size: .72rem;
  color: var(--ink-soft);
  margin-right: .25rem;
  font-weight: 500;
  letter-spacing: .02em;
  border: 1px solid rgba(255,255,255,.10);
}
.tag.yes { background: var(--accent-tint); color: var(--accent); border-color: var(--accent-tint-2); }
.tag.no  { background: var(--warn-tint); color: var(--warn); border-color: rgba(229,120,120,.35); }

/* ---------- Entity (resident/pet) cards inside an address section ---------- */
.entity-card {
  position: relative;
  padding: .9rem 1.1rem .9rem 1.25rem;
  background: var(--card-alt);
  border: 1px solid var(--line);
  border-left: 4px solid var(--section-color, var(--accent));
  border-radius: var(--radius);
  margin-bottom: .85rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
  color: var(--ink);
  transition: box-shadow .15s ease, background-color .15s ease;
}
.entity-card:hover {
  background: var(--card-elev);
  box-shadow: 0 2px 6px rgba(0,0,0,.30), 0 8px 18px rgba(0,0,0,.22);
}
.entity-card:nth-of-type(even) { background: color-mix(in srgb, var(--section-color, var(--accent)) 8%, var(--card-alt)); }
.entity-card:nth-of-type(even):hover { background: color-mix(in srgb, var(--section-color, var(--accent)) 14%, var(--card-elev)); }
.entity-card:last-of-type { margin-bottom: 1rem; }
.entity-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: .65rem;
}
.entity-card h3 {
  font-size: 1.1rem;
  color: var(--section-color, #ffffff);
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 650;
}

/* ---------- Interests block ---------- */
.interests-block {
  margin-top: .7rem;
  padding: .65rem .85rem;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius);
  background: rgba(255,255,255,.04);
}
.interests-block summary {
  color: var(--section-color, var(--accent));
  cursor: pointer;
  font-weight: 500;
  font-size: .92rem;
}
.interests-block summary:hover { filter: brightness(1.15); }
.interests-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem;
  margin-top: .65rem;
}
.interest-cat {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: .5rem .7rem .6rem;
  background: var(--bg-tint);
  color: var(--ink);
}
.interest-cat legend {
  font-weight: 600;
  font-size: .82rem;
  color: #ffffff;
  padding: 0 .35rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.interest-cat label.checkbox {
  display: block;
  font-size: .9rem;
  padding: .12rem 0;
  cursor: pointer;
  color: var(--ink-soft);
}
.interest-cat label.checkbox:hover { color: #ffffff; }
.interest-cat label.checkbox input { margin-right: .45rem; accent-color: var(--section-color, var(--accent)); }

/* ---------- Stat cards ---------- */
.stat {
  flex: 1 1 160px;
  padding: .9rem 1rem 1rem;
  background: var(--card-alt);
  border-radius: var(--radius);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
  box-shadow: var(--card-shadow);
  color: var(--ink);
}
.stat::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--accent);
  box-shadow: 0 0 14px -1px var(--accent);
}
.stat-num {
  font-size: 1.65rem;
  font-weight: 650;
  color: #ffffff;
  letter-spacing: -.01em;
  line-height: 1.1;
}
.stat-label {
  font-size: .72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
  margin-top: .25rem;
}
.row > .stat:nth-child(2n)::before {
  background: var(--c-payments);
  box-shadow: 0 0 14px -1px var(--c-payments);
}
.row > .stat:nth-child(3n)::before {
  background: var(--gold);
  box-shadow: 0 0 14px -1px var(--gold);
}
.row > .stat:nth-child(4n)::before {
  background: var(--c-interests);
  box-shadow: 0 0 14px -1px var(--c-interests);
}

/* ---------- Small helpers ---------- */
strong { font-weight: 650; color: #ffffff; }
hr { border: none; border-top: 1px solid var(--line); margin: 1rem 0; }

input[type="checkbox"], input[type="radio"] { accent-color: var(--section-color, var(--accent)); }

/* Selection */
::selection { background: var(--accent-tint-2); color: #ffffff; }

/* Scrollbar polish (WebKit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #3a567f; border-radius: 6px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: #506e9a; }
::-webkit-scrollbar-track { background: transparent; }

/* Print-friendly */
@media print {
  @page { size: letter; margin: 0.5in; }
  body { background: #fff; background-image: none; color: #000; }
  .topbar, .context-strip, .actions, .btn, .no-print { display: none !important; }
  main { padding: 0; max-width: none; }
  .card {
    box-shadow: none; border: 1px solid #bbb; background: #fff; color: #000;
    page-break-inside: avoid; break-inside: avoid;
    margin: 0 0 .5rem 0; padding: .6rem .8rem;
  }
  .card h2, .card h3, strong, .topbar h1 a, .muted, a { color: #000; }
  .muted { color: #555 !important; }
  .card[class*="section-"]::before { background: #999; box-shadow: none; }
  /* Tiles & tables: white-on-paper, keep borders */
  .stat { background: #fff; border: 1px solid #ccc; color: #000; }
  .stat-num { color: #000; }
  table.data { background: #fff; color: #000; }
  table.data th, table.data td { border: 1px solid #bbb; background: #fff; color: #000; }
  table.data thead th { background: #eee; }
  /* Don't split tables across pages mid-row */
  table.data { page-break-inside: auto; }
  table.data tr { page-break-inside: avoid; page-break-after: auto; }
  /* Tighter type for paper density */
  body, .card, table.data { font-size: 10pt; }
  h1, h2 { font-size: 14pt; }
  h3 { font-size: 12pt; }
  a { text-decoration: none; }
}
