/* ============================================================
   HOA Manager — Chimney Hill civic-ledger theme  (CSP-safe)
   Self-hosted fonts; no inline styles/scripts (style-src 'self').
   Fonts live at /static/fonts → from here that is ../fonts/.
   ============================================================ */

/* ── self-hosted variable fonts (subset → woff2) ── */
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;src:url("../fonts/fraunces.woff2") format("woff2")}
@font-face{font-family:"Fraunces";font-style:italic;font-weight:100 900;font-display:swap;src:url("../fonts/fraunces-italic.woff2") format("woff2")}
@font-face{font-family:"Public Sans";font-style:normal;font-weight:100 900;font-display:swap;src:url("../fonts/publicsans.woff2") format("woff2")}
@font-face{font-family:"Spline Sans Mono";font-style:normal;font-weight:100 900;font-display:swap;src:url("../fonts/splinesansmono.woff2") format("woff2")}

:root{
  --bg:#f1e9da; --paper:#f1e9da; --paper-2:#e9dfcb; --card:#fbf6ec; --card-edge:#fffdf8;
  --ink:#211f1a; --ink-soft:#5f584a; --ink-faint:#8a8170;
  --line:#d9cdb4; --line-soft:#e6dcc7;
  --brick:#b1492c; --brick-deep:#8c3620; --brick-soft:#f6e0d8; --brick-edge:#e7c1b4;
  --sage:#566b46; --accent:#566b46; --sage-soft:#e1e7d3; --sage-edge:#c5d2af;
  --brass:#bb8a3e; --brass-soft:#f0e2c2; --brass-edge:#e1c98f;
  --slate:#4f6f82; --slate-soft:#dde8ee; --slate-edge:#bcd2de;
  --warn:#b1492c;
  --shadow-sm:0 1px 2px rgba(54,40,20,.10);
  --shadow:0 8px 24px -10px rgba(60,42,18,.32),0 2px 6px -2px rgba(60,42,18,.18);
  --shadow-lg:0 30px 70px -28px rgba(50,32,12,.55),0 8px 22px -12px rgba(50,32,12,.30);
  --radius:14px; --radius-sm:9px; --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;font-family:"Public Sans",system-ui,sans-serif;font-size:16px;line-height:1.5;
  color:var(--ink);background:var(--paper);min-height:100vh;overflow-x:hidden}

/* ── layered paper atmosphere (data-URI bg allowed by img-src 'self' data:) ── */
body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    radial-gradient(1200px 700px at 88% -8%, rgba(187,138,62,.16), transparent 60%),
    radial-gradient(1000px 800px at -6% 108%, rgba(86,107,70,.14), transparent 58%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E"),
    linear-gradient(170deg,var(--paper) 0%,var(--paper-2) 100%)}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='820' height='820' viewBox='0 0 820 820'%3E%3Cg fill='none' stroke='%23b89a5f' stroke-opacity='.16' stroke-width='1.2'%3E%3Cpath d='M-40 250 C160 180 300 360 520 300 740 240 860 380 1020 320'/%3E%3Cpath d='M-40 330 C160 260 300 440 520 380 740 320 860 460 1020 400'/%3E%3Cpath d='M-40 420 C170 350 320 520 540 470 760 420 880 540 1040 490'/%3E%3Cpath d='M-40 520 C180 460 340 610 560 560 780 510 900 620 1060 580'/%3E%3Cpath d='M-40 630 C200 580 360 710 580 660 800 610 920 700 1080 670'/%3E%3C/g%3E%3C/svg%3E");
  background-size:880px;background-position:60% 40%}

/* ───────── masthead ───────── */
header.topbar{display:flex;gap:.35rem;align-items:center;padding:13px 28px;
  background:linear-gradient(180deg,rgba(251,246,236,.92),rgba(251,246,236,.78));
  backdrop-filter:blur(8px);border-bottom:1.5px solid var(--line);
  position:sticky;top:0;z-index:40}
header.topbar a{color:var(--ink-soft);text-decoration:none;font-weight:600;font-size:.9rem;
  padding:7px 13px;border-radius:9px;transition:background .15s,color .15s}
header.topbar a:hover{background:var(--paper);color:var(--ink)}
header.topbar a[href="/logout"]{color:var(--brick)}
header.topbar a[href="/logout"]:hover{background:var(--brick-soft)}
header.topbar .spacer{flex:1}
header.topbar > span{font-family:"Spline Sans Mono",monospace;font-size:.74rem;letter-spacing:.02em;
  color:var(--ink-faint);padding:0 6px}
header.topbar .nav-short{display:none}  /* short label shown only on narrow screens */

main{max-width:1080px;margin:0 auto;padding:30px 28px 80px}

/* ───────── typography ───────── */
h1{font-family:"Fraunces",serif;font-weight:600;font-size:2.05rem;line-height:1.08;letter-spacing:-.01em;margin:0}
h2{font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem;margin:0}
.page-head{margin-bottom:22px}
.eyebrow{font-family:"Spline Sans Mono",monospace;font-size:.7rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--brick);margin:0 0 7px}
.panel-title{font-family:"Fraunces",serif;font-weight:600;font-size:1.16rem;margin:0 0 14px;
  display:flex;align-items:center;gap:11px}
.panel-title::after{content:"";flex:1;height:1px;background:var(--line)}
.muted{color:var(--ink-faint)}
.error{color:var(--brick);font-weight:600;background:var(--brick-soft);border:1px solid var(--brick-edge);
  border-radius:var(--radius-sm);padding:10px 13px;margin:0 0 16px}

/* ───────── toolbar / command field ───────── */
.toolbar{display:flex;gap:11px;align-items:center;margin:0 0 20px;flex-wrap:wrap}
.toolbar .cmd{flex:1 1 auto;max-width:440px;display:flex;gap:8px}
.toolbar input[type=text]{flex:1;max-width:none}
.btn-link{text-decoration:none}

/* ───────── roster (directory table) ───────── */
.roster-shell{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
table{width:100%;border-collapse:collapse;background:var(--card)}
.roster-shell table{border:0}
thead th{font-family:"Public Sans";font-size:.68rem;letter-spacing:.11em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:700;text-align:left;white-space:nowrap;
  padding:13px 18px;background:linear-gradient(180deg,#fcf8ee,var(--card));
  border-bottom:1.5px solid var(--line-soft)}
td{padding:13px 18px;border-bottom:1px solid var(--line-soft);vertical-align:middle;font-size:.92rem}
tbody tr{transition:background .12s}
tbody tr:hover td{background:var(--paper)}
tbody tr:last-child td{border-bottom:none}
a.row-link{color:var(--ink);text-decoration:none;display:block;font-weight:600}
a.row-link:hover{color:var(--brick)}
a.row-link.lot{font-family:"Spline Sans Mono",monospace;font-weight:600;font-size:.84rem;color:var(--ink-soft)}
a.row-link.lot:hover{color:var(--brick)}
.who{display:flex;flex-direction:column;line-height:1.3;padding:1px 0}
.who + .who{margin-top:5px}
.who .wn-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.who .wn{font-weight:600}
.who .we{font-size:.82rem;color:var(--ink-soft);word-break:break-word}
.who .wp{font-family:"Spline Sans Mono",monospace;font-size:.8rem;color:var(--ink-faint)}

/* per-person owner/renter tag (directory + detail) */
.role-tag{font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 7px;border-radius:5px;border:1px solid var(--line);background:var(--paper);
  color:var(--ink-soft);white-space:nowrap;vertical-align:middle}
.role--owner{color:var(--sage);border-color:var(--sage-edge);background:var(--sage-soft)}
.role--renter{color:var(--slate);border-color:var(--slate-edge);background:var(--slate-soft)}
.role--family{color:var(--brass);border-color:var(--brass-edge);background:var(--brass-soft)}
.role--other{color:var(--ink-faint);border-color:var(--line);background:var(--paper)}
td.flags{white-space:nowrap}
.empty{padding:40px 20px;text-align:center;color:var(--ink-faint);
  font-family:"Fraunces",serif;font-style:italic;font-size:1.05rem}

/* ───────── summary ledger ───────── */
.ledger{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin:0 0 22px;
  background:var(--line);border:1.5px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm)}
.stat{background:var(--card);padding:16px 20px;display:flex;flex-direction:column;gap:4px}
.stat .lab{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:700}
.stat .lab::before{content:"";display:inline-block;width:7px;height:7px;border-radius:2px;
  margin-right:8px;vertical-align:middle;background:var(--ink-faint)}
.stat:nth-child(1) .lab::before{background:var(--brick)}
.stat:nth-child(2) .lab::before{background:var(--sage)}
.stat:nth-child(3) .lab::before{background:var(--slate)}
.stat:nth-child(4) .lab::before{background:var(--brass)}
.stat .val{font-family:"Spline Sans Mono",monospace;font-weight:600;font-size:1.7rem;
  letter-spacing:-.01em;font-variant-numeric:tabular-nums;line-height:1.05}

/* toolbar result count */
.toolbar .count{margin-left:auto;font-family:"Spline Sans Mono",monospace;font-size:.78rem;
  color:var(--ink-faint);white-space:nowrap}

/* roster filter pills */
.roster-filters{display:flex;gap:8px;margin:0 0 18px;flex-wrap:wrap}
.filter-btn{font-family:"Spline Sans Mono",monospace;font-size:.74rem;font-weight:600;
  letter-spacing:.03em;color:var(--ink-soft);text-decoration:none;padding:5px 12px;
  border:1px solid var(--line);border-radius:999px;background:var(--paper)}
.filter-btn:hover{border-color:var(--brass);color:var(--ink)}
.filter-btn.on{color:#fff;background:var(--brick);border-color:var(--brick)}

/* monogram + address cell */
td:first-child{min-width:240px}
.addr-cell{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.seal{flex:0 0 auto;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
  font-family:"Fraunces",serif;font-weight:600;font-size:.92rem;letter-spacing:.02em;color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14),var(--shadow-sm)}
.seal--brick{background:linear-gradient(150deg,var(--brick),var(--brick-deep))}
.seal--sage{background:linear-gradient(150deg,var(--sage),#3f5235)}
.seal--slate{background:linear-gradient(150deg,var(--slate),#3a5161)}
.seal--brass{background:linear-gradient(150deg,var(--brass),#8f6a2a)}
.seal--muted{background:var(--paper-2);color:var(--ink-faint);box-shadow:inset 0 0 0 1px var(--line);font-size:1.1rem}
.addr-text{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.addr-line{font-weight:600;font-size:.98rem}
.addr-cell:hover .addr-line{color:var(--brick)}
.addr-sub{font-size:.76rem;color:var(--ink-faint)}

/* row chevron */
.cell-chev{width:1%;white-space:nowrap;text-align:right}
.row-chev{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;
  color:var(--ink-faint);text-decoration:none;font-size:1.45rem;line-height:1;transition:color .15s,background .15s}
tbody tr:hover .row-chev{color:var(--brick);background:var(--brick-soft)}

@media (max-width:760px){
  .ledger{grid-template-columns:repeat(2,1fr)}
  .cell-chev,thead th:last-child{display:none}
}

/* ───────── tags / badges ───────── */
.tag,.badge{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 8px;border-radius:6px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);
  margin-right:4px}
.tag.arc,.badge.warn{color:var(--brass);border-color:var(--brass-edge);background:var(--brass-soft)}
.tag.viol{color:var(--brick);border-color:var(--brick-edge);background:var(--brick-soft)}
.tag.rent,.badge.rental{color:var(--slate);border-color:var(--slate-edge);background:var(--slate-soft)}
.tag.own{color:var(--sage);border-color:var(--sage-edge);background:var(--sage-soft)}
.tag.due{color:var(--brick);border-color:var(--brick-edge);background:var(--brick-soft)}

/* ───────── forms (shared) ───────── */
label{font-weight:600;font-size:.82rem;color:var(--ink-soft)}
input[type=text],input[type=password],input[type=email],input[type=tel],select,textarea{
  width:100%;font-family:inherit;font-size:.94rem;color:var(--ink);background:var(--card-edge);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;margin-top:5px}
textarea{resize:vertical}
select{cursor:pointer}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brick);background:#fffdf8;
  box-shadow:0 0 0 3px rgba(177,73,44,.13)}

button,input[type=submit]{font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;
  border:1.5px solid transparent;border-radius:var(--radius-sm);padding:10px 18px;
  color:#fff;background:linear-gradient(150deg,var(--brick),var(--brick-deep));
  box-shadow:var(--shadow-sm);transition:filter .15s,transform .12s,border-color .15s,background .15s}
button:hover,input[type=submit]:hover{filter:brightness(1.06);transform:translateY(-1px)}
button:active,input[type=submit]:active{transform:translateY(0)}
.btn-primary{color:#fff;background:linear-gradient(150deg,var(--brick),var(--brick-deep))}

/* ghost / secondary (search, disclosures) */
.cmd button{color:var(--ink);background:var(--paper);border-color:var(--line);box-shadow:none}
.cmd button:hover{filter:none;border-color:var(--ink-soft);background:var(--card-edge)}

/* destructive = restrained outline, not alarming solid red */
button.danger{color:var(--brick);background:var(--paper);border-color:var(--line);box-shadow:none}
button.danger:hover{filter:none;border-color:var(--brick);background:var(--brick-soft)}

form.stack{display:flex;flex-direction:column;gap:.85rem;max-width:460px;
  background:var(--card);padding:22px;border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
form.stack button,form.stack input[type=submit]{align-self:flex-start}

/* ───────── property detail layout ───────── */
.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:20px;align-items:start}
.panel{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px}
.panel form.stack,.panel > form.stack{background:none;border:0;box-shadow:none;padding:0;max-width:none}
/* emergency contacts: full-width panel below the two top panels, owner/renter groups */
.panel.emergency{grid-column:1 / -1}
.em-hint{margin:-4px 0 16px;color:var(--ink-faint);font-size:.8rem}
.em-group{margin-bottom:16px}
.em-group:last-child{margin-bottom:0}
.em-head{font-family:"Spline Sans Mono",monospace;font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-faint);margin:0 0 8px}
.em-notes{margin:4px 0 0;color:var(--ink-soft);font-size:.82rem;font-style:italic}
/* county (CAD) record panel */
.panel.cad{grid-column:1 / -1}
.cad-flag{margin:0 0 12px;padding:8px 12px;border-radius:var(--radius-sm);
  background:var(--brick-soft);border:1px solid var(--brick-edge);color:var(--brick);
  font-size:.85rem;font-weight:600}
.cad-meta{margin:10px 0 0;color:var(--ink-faint);font-size:.78rem;font-family:"Spline Sans Mono",monospace}

.readonly-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.readonly-list li{background:var(--paper);border:1.2px solid var(--line-soft);border-radius:var(--radius-sm);
  padding:10px 13px;font-size:.9rem}
.readonly-list li.error{background:var(--brick-soft);border-color:var(--brick-edge);color:var(--brick);font-weight:600}
.readonly-list a{color:var(--brick);text-decoration:none;font-family:"Spline Sans Mono",monospace;font-size:.85rem}

/* residents fieldset styled as a panel */
fieldset{border:1.5px solid var(--line);background:var(--card);border-radius:var(--radius);
  box-shadow:var(--shadow);margin:0;padding:22px}
legend{font-family:"Fraunces",serif;font-weight:600;font-size:1.16rem;padding:0 8px;color:var(--ink)}
.detail-grid fieldset{margin:0}

.resident{padding:15px 0;border-bottom:1.5px solid var(--line-soft)}
.resident:first-of-type{padding-top:4px}
.resident:last-of-type{border-bottom:none;padding-bottom:4px}
.resident > strong{font-family:"Fraunces",serif;font-weight:600;font-size:1.08rem}
.resident ul{list-style:none;margin:8px 0 4px;padding:0;display:flex;flex-direction:column;gap:5px}
.resident ul li{font-family:"Spline Sans Mono",monospace;font-size:.85rem;color:var(--ink-soft);
  background:var(--paper);border:1.1px solid var(--line-soft);border-radius:7px;padding:5px 10px;width:fit-content}

/* disclosure */
details{margin-top:10px}
details summary{cursor:pointer;font-weight:600;font-size:.8rem;color:var(--brick);
  list-style:none;display:inline-flex;align-items:center;gap:7px;
  border:1.4px solid var(--line);border-radius:8px;padding:6px 12px;background:var(--paper);
  transition:border-color .15s,background .15s;user-select:none}
details summary::-webkit-details-marker{display:none}
details summary::before{content:"\270E";font-size:.85em}
details[open] summary{border-color:var(--brass);background:var(--brass-soft);color:var(--ink)}
details summary:hover{border-color:var(--brass)}
details[open] > summary{margin-bottom:14px}
details > form.stack,details > .phonerow,details > p{margin-left:2px}
details > form.stack{background:var(--paper);border:1.2px solid var(--line-soft);
  border-radius:var(--radius-sm);padding:15px;box-shadow:none;max-width:none;margin-top:11px;gap:.7rem}

/* phone edit rows */
.phonerow{display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin:10px 0}
.phonerow-edit{display:flex;gap:6px;align-items:center;flex-wrap:wrap;max-width:none;
  background:#fffdf8;border:1.3px solid var(--line);border-radius:var(--radius-sm);padding:8px 10px}
.phonerow-edit input[type=text]{width:auto;flex:1 1 130px;margin-top:0;font-family:"Spline Sans Mono",monospace;font-size:.84rem}
.phonerow-edit select{width:auto;margin-top:0;padding:8px 8px}
.phonerow-edit .checkrow{font-size:.78rem;color:var(--ink-soft)}
.phonerow-edit button{padding:8px 14px;font-size:.82rem}

.checkrow{display:flex;gap:.5rem;align-items:center}
.checkrow input{width:auto;margin-top:0;accent-color:var(--brick)}
.checkrow label{font-weight:500;color:var(--ink-soft)}

td > div + div{margin-top:.2rem}

/* ───────── locate "who lives here" ───────── */
#locate-status{font-size:.88rem;color:var(--ink-soft);min-height:1.2em}
.match{background:var(--card);border:1.5px solid var(--line);border-left:5px solid var(--sage);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin:18px 0}
.match h2 a{font-family:"Fraunces",serif;color:var(--ink);text-decoration:none}
.match h2 a:hover{color:var(--brick)}

/* ───────── entrance ───────── */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.anim{opacity:0;animation:rise .6s var(--ease) forwards}
.d1{animation-delay:.06s}
.d2{animation-delay:.13s}
.d3{animation-delay:.19s}
.d4{animation-delay:.24s}

@media (max-width:820px){
  .detail-grid{grid-template-columns:1fr}
  main{padding:22px 18px 60px}
  /* one-row horizontal swipe strip, scrolls away (not sticky) on narrow screens */
  header.topbar{padding:8px 12px;gap:.2rem;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;
    position:static;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  header.topbar::-webkit-scrollbar{display:none}
  header.topbar a{flex:none;white-space:nowrap;font-size:.84rem;padding:6px 10px}
  header.topbar .spacer{display:none}
  header.topbar > span{display:none}        /* identity text hidden on mobile */
  header.topbar .nav-full{display:none}
  header.topbar .nav-short{display:inline}  /* 'Locate' instead of 'Who lives here?' */
  h1{font-size:1.7rem}
}
@media (prefers-reduced-motion:reduce){
  .anim{animation:none;opacity:1}
  *{transition:none!important}
}

/* --- dues payment + ledger --- */
.dues{max-width:560px}
.dues-closed{color:var(--ink-soft);background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px 18px}
.dues-note{color:var(--ink-faint);font-size:.82rem;margin-top:20px}

/* radio-card picker (street / house) */
.dues-pick{margin:0}
/* each step is a padded panel; the card grid sits inset within it */
.pick-step{margin:0 0 14px;padding:11px 13px 13px;background:var(--paper-2);
  border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.pick-step legend{font-family:"Fraunces",serif;font-weight:600;font-size:1.12rem;
  padding:0 9px;color:var(--ink)}
.pick-step legend b{color:var(--brick-deep)}
.pick-grid{border:0;padding:0;margin:9px 0 0}
.pick-grid--street{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:11px}
.pick-grid--house{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:11px}
.pick{display:block;position:relative}
.pick input{position:absolute;opacity:0;width:0;height:0}
.pick-card{display:flex;flex-direction:column;justify-content:center;gap:3px;cursor:pointer;
  min-height:54px;height:100%;
  background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius-sm);
  padding:13px 15px;box-shadow:var(--shadow-sm);transition:transform .12s var(--ease),
  border-color .12s,background .12s,box-shadow .12s}
.pick-card:hover{transform:translateY(-2px);border-color:var(--brick-edge);box-shadow:var(--shadow)}
.pick-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.15}
.pick-count{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-weight:700}
.pick-no{font-family:"Spline Sans Mono",monospace;font-weight:600;font-size:1.35rem;color:var(--ink);line-height:1}
.pick-sub{font-size:.72rem;letter-spacing:.04em;color:var(--ink-faint)}
.pick input:checked + .pick-card{border-color:var(--brick);background:var(--brick-soft);
  box-shadow:0 0 0 2px var(--brick) inset,var(--shadow-sm)}
.pick input:checked + .pick-card .pick-no,
.pick input:checked + .pick-card .pick-name{color:var(--brick-deep)}
.pick input:focus-visible + .pick-card{outline:2px solid var(--brick);outline-offset:2px}

.dues-actions{display:flex;align-items:center;justify-content:flex-end;gap:16px;margin-top:22px}
.dues-back{margin-right:auto;text-decoration:none;font-weight:600;font-size:.85rem;color:var(--ink-soft)}
.dues-back:hover{color:var(--brick)}
.dues-ledger .set-fee{background:var(--card);border:1.5px solid var(--line);
  border-radius:var(--radius);padding:16px 20px;margin:0 0 22px;
  display:flex;flex-direction:column;gap:10px;max-width:420px;box-shadow:var(--shadow-sm)}
.dues-ledger .set-fee h2{margin:0 0 4px;font-size:1rem}
.needs-review{color:var(--warn);display:flex;align-items:center;gap:8px}
.needs-review::before{content:"";width:9px;height:9px;border-radius:2px;background:var(--warn)}
tr.flagged{background:var(--brick-soft)}

/* ============================================================
   Governing Documents — "Recorded Instrument"  (CSP-safe)
   Public bylaws pages: deed register, full text, quick reference.
   Reuses theme tokens; tones mirror the document colour legend
   (Restrictions white→slate, Bylaws green→sage, Declaration yellow→brass).
   ============================================================ */
.deed{--tone:var(--slate);--tone-soft:var(--slate-soft);--tone-edge:var(--slate-edge)}
.deed--slate{--tone:var(--slate);--tone-soft:var(--slate-soft);--tone-edge:var(--slate-edge)}
.deed--sage{--tone:var(--sage);--tone-soft:var(--sage-soft);--tone-edge:var(--sage-edge)}
.deed--brass{--tone:var(--brass);--tone-soft:var(--brass-soft);--tone-edge:var(--brass-edge)}

/* ── masthead (index / faq) ── */
.deed-head{margin:6px 0 22px}
.deed-kicker{margin:0 0 6px;font-family:"Spline Sans Mono",monospace;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--brass)}
.deed-head h1{font-size:2.4rem}
.deed-sub{margin:10px 0 0;max-width:60ch;color:var(--ink-soft);font-size:1.02rem;line-height:1.55}

/* ── tab nav ── */
.deed-nav{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0 0 26px;
  padding:7px;background:linear-gradient(180deg,var(--card-edge),var(--card));
  border:1.5px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.deed-nav a{text-decoration:none;font-weight:600;font-size:.86rem;color:var(--ink-soft);
  padding:8px 14px;border-radius:9px;border:1.5px solid transparent;transition:
  background .15s,color .15s,border-color .15s}
.deed-nav a:hover{background:var(--paper);color:var(--ink)}
.deed-nav a.is-current{background:var(--ink);color:var(--card-edge);border-color:var(--ink)}
.deed-nav .deed-pdf{margin-left:auto;color:var(--brick);font-family:"Spline Sans Mono",monospace;
  font-size:.78rem;letter-spacing:.02em}
.deed-nav .deed-pdf:hover{background:var(--brick-soft);color:var(--brick-deep)}
.deed-nav--switch .deed-back{color:var(--ink-faint);font-weight:600}
.deed-nav--switch .deed-back:hover{color:var(--ink)}
.deed-nav--switch a.is-current{background:var(--tone);border-color:var(--tone);color:#fff}

/* ── deed register (index cards) ── */
.deed-index{list-style:none;margin:0;padding:0;display:grid;gap:16px}
.deed-card{--tone:var(--slate)}
.deed-card > a{display:flex;align-items:stretch;gap:0;text-decoration:none;color:inherit;
  background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .16s var(--ease),
  box-shadow .16s var(--ease),border-color .16s}
.deed-card > a:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--tone-edge)}
.deed-card > a:focus-visible{outline:2px solid var(--tone);outline-offset:3px}
.deed-tab{flex:none;width:30px;display:flex;align-items:flex-end;justify-content:center;
  padding:10px 0;writing-mode:vertical-rl;transform:rotate(180deg);
  font-family:"Spline Sans Mono",monospace;font-size:.6rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--tone);background:var(--tone-soft);
  border-right:1.5px solid var(--tone-edge)}
.deed-no{flex:none;align-self:center;padding:0 22px 0 24px;font-family:"Fraunces",serif;
  font-weight:600;font-size:2.6rem;color:var(--tone);line-height:1;
  font-variant-numeric:lining-nums;opacity:.85}
.deed-card-body{padding:20px 24px 20px 0;display:flex;flex-direction:column;gap:5px}
.deed-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.42rem;line-height:1.1;color:var(--ink)}
.deed-blurb{color:var(--ink-soft);font-size:.95rem;line-height:1.5;max-width:58ch}
.deed-open{margin-top:6px;font-family:"Spline Sans Mono",monospace;font-size:.74rem;
  letter-spacing:.06em;color:var(--tone);font-weight:600}

.deed-foot{margin:30px 0 0;display:flex;flex-direction:column;gap:14px}
.deed-foot-q{margin:0;padding:16px 20px;background:var(--sage-soft);border:1.5px solid var(--sage-edge);
  border-radius:var(--radius);color:var(--ink);font-size:.98rem;line-height:1.55}
.deed-foot-q a,.deed-disclaimer a{color:var(--brick);font-weight:600}
.deed-disclaimer{margin:0;font-size:.82rem;line-height:1.5;color:var(--ink-faint);
  padding-left:14px;border-left:2px solid var(--line)}
.deed-disclaimer--lead{margin:0 0 24px;padding:13px 16px;border-left:4px solid var(--brass);
  background:var(--brass-soft);color:var(--ink-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0}

/* ── full-text page ── */
.deed-paper{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.deed-stamp{position:relative;padding:30px 34px 26px;border-bottom:1.5px solid var(--line);
  background:linear-gradient(180deg,var(--card-edge),var(--card))}
.deed-stamp h1{font-size:1.95rem;max-width:30ch}
.deed-stamp .deed-kicker{color:var(--tone)}
.deed-seal{position:absolute;top:24px;right:30px;width:84px;height:84px;border-radius:50%;
  border:2px solid var(--tone);color:var(--tone);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1px;transform:rotate(-9deg);opacity:.62;
  box-shadow:inset 0 0 0 4px var(--card),inset 0 0 0 5px var(--tone-edge)}
.deed-seal b{font-family:"Fraunces",serif;font-size:1.7rem;line-height:1;font-weight:600}
.deed-seal i{font-family:"Spline Sans Mono",monospace;font-style:normal;font-size:.5rem;
  letter-spacing:.18em;text-transform:uppercase}

.deed-layout{display:grid;grid-template-columns:230px 1fr;gap:0}
.deed-toc{align-self:start;position:sticky;top:74px;max-height:calc(100vh - 90px);overflow:auto;
  padding:22px 18px 26px 24px;border-right:1.5px solid var(--line);background:var(--paper)}
.deed-toc-h{margin:0 0 10px;font-family:"Spline Sans Mono",monospace;font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.deed-toc nav{display:flex;flex-direction:column;gap:1px}
.deed-toc a{text-decoration:none;color:var(--ink-soft);font-size:.82rem;line-height:1.32;
  padding:4px 8px;border-radius:7px;border-left:2px solid transparent}
.deed-toc a:hover{background:var(--card);color:var(--ink);border-left-color:var(--tone)}
.deed-toc a.lvl-2{font-weight:700;color:var(--ink);margin-top:9px;font-size:.78rem;
  letter-spacing:.02em;text-transform:uppercase}
.deed-toc a.lvl-3{padding-left:16px}

/* rendered markdown body */
.deed-text{padding:30px 40px 34px;min-width:0;max-width:74ch}
.deed-text h2{font-size:1.34rem;margin:34px 0 4px;padding-top:18px;border-top:1.5px solid var(--line);
  color:var(--ink);scroll-margin-top:78px}
.deed-text > h2:first-child{margin-top:6px;padding-top:0;border-top:0}
.deed-text h3{font-family:"Fraunces",serif;font-weight:600;font-size:1.08rem;line-height:1.25;
  margin:26px 0 6px;padding:8px 0 8px 16px;border-left:3px solid var(--tone);color:var(--ink);
  scroll-margin-top:78px}
.deed-text h4{font-family:"Public Sans",sans-serif;font-size:.96rem;margin:18px 0 4px;color:var(--ink)}
.deed-text p{margin:0 0 13px;line-height:1.66;color:var(--ink-soft)}
.deed-text strong{color:var(--ink);font-weight:700}
.deed-text ul,.deed-text ol{margin:0 0 14px;padding-left:24px;line-height:1.6;color:var(--ink-soft)}
.deed-text li{margin:3px 0}
.deed-text hr{border:0;height:1px;background:var(--line);margin:26px 0}
.deed-text a{color:var(--brick);font-weight:600}
.deed-text .deed-disclaimer{margin-top:28px;padding-top:14px;border-left:0;border-top:1.5px solid var(--line)}

/* ── quick reference (faq) ── */
.deed-faq{max-width:780px}
.faq-cat{margin:0 0 26px}
.faq-cat h2{font-size:1.18rem;margin:0 0 12px;color:var(--ink);
  padding-bottom:8px;border-bottom:2px solid var(--brass-edge)}
/* override the app-wide <details> chrome (pencil marker, brick text) for FAQ cards */
.faq-item{--tone:var(--ink-soft);margin:0 0 10px;background:var(--card);
  border:1.5px solid var(--line);border-left:4px solid var(--tone);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden;transition:border-color .15s,box-shadow .15s}
.faq--slate{--tone:var(--slate)}
.faq--sage{--tone:var(--sage)}
.faq--brass{--tone:var(--brass)}
.faq-item:hover{box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:14px;
  padding:15px 18px;font-family:"Fraunces",serif;font-weight:600;font-size:1.06rem;
  color:var(--ink);border:0;background:none;border-radius:0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:none}
.faq-q{flex:1}
.faq-mark{flex:none;width:18px;height:18px;position:relative}
.faq-mark::before,.faq-mark::after{content:"";position:absolute;background:var(--tone);
  border-radius:2px;transition:transform .2s var(--ease),opacity .2s}
.faq-mark::before{top:8px;left:1px;width:16px;height:2.4px}
.faq-mark::after{top:1px;left:7.8px;width:2.4px;height:16px}
.faq-item[open]{border-color:var(--tone-edge,var(--line));border-left-color:var(--tone)}
.faq-item[open] summary{background:var(--tone-soft,var(--paper))}
.faq-item[open] .faq-mark::after{transform:scaleY(0);opacity:0}
.faq-item summary:hover{background:var(--paper)}
.faq-item summary:focus-visible{outline:2px solid var(--tone);outline-offset:-2px}
.faq-a{padding:4px 18px 16px 22px}
.faq-a p{margin:0 0 10px;line-height:1.62;color:var(--ink-soft)}
.faq-a strong{color:var(--ink)}
.faq-src{margin:12px 0 0 !important;font-family:"Spline Sans Mono",monospace;font-size:.72rem;
  letter-spacing:.03em;color:var(--tone);font-weight:600;padding-top:9px;border-top:1px dashed var(--line)}

/* tone-soft fallbacks so [open] summary tints correctly */
.faq--slate{--tone-soft:var(--slate-soft);--tone-edge:var(--slate-edge)}
.faq--sage{--tone-soft:var(--sage-soft);--tone-edge:var(--sage-edge)}
.faq--brass{--tone-soft:var(--brass-soft);--tone-edge:var(--brass-edge)}

/* ── entrance: staggered reveal (respects reduced-motion) ── */
@media (prefers-reduced-motion:no-preference){
  .deed-card,.deed-paper,.faq-cat{animation:deed-rise .5s var(--ease) both}
  .deed-card:nth-child(1){animation-delay:.04s}
  .deed-card:nth-child(2){animation-delay:.12s}
  .deed-card:nth-child(3){animation-delay:.2s}
  .faq-cat:nth-child(odd){animation-delay:.06s}
  .faq-cat:nth-child(even){animation-delay:.12s}
}
@keyframes deed-rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── responsive ── */
@media (max-width:760px){
  .deed-head h1{font-size:1.95rem}
  .deed-layout{grid-template-columns:1fr}
  .deed-toc{position:static;max-height:none;border-right:0;border-bottom:1.5px solid var(--line)}
  .deed-text{padding:24px 22px 28px}
  .deed-seal{width:62px;height:62px;top:20px;right:20px}
  .deed-seal b{font-size:1.25rem}
  .deed-no{font-size:2rem;padding:0 14px}
}

/* --- locate map: surveyor's plat --- */
.locate-bar{display:flex;align-items:center;gap:14px;margin:14px 0 18px;flex-wrap:wrap}
#locate-status{color:var(--ink-faint);font-size:.85rem}
/* pin legend */
.map-legend{display:inline-flex;gap:1rem;flex-wrap:wrap;
  font-family:"Spline Sans Mono",monospace;font-size:.7rem;color:var(--ink-soft)}
.lg{display:inline-flex;align-items:center;gap:.4rem}
.lg::before{content:"";width:.72rem;height:.72rem;border-radius:50%;border:1.5px solid #fff;box-shadow:var(--shadow-sm)}
.lg--own::before{background:var(--slate)}
.lg--rent::before{background:var(--brass)}
.lg--vacant::before{background:var(--ink)}
.lg--you::before{background:var(--sage);box-shadow:0 0 0 3px rgba(86,107,70,.32)}

.map-frame{position:relative;margin:6px 0 24px}
.map-viewport{position:relative;overflow:auto;height:70vh;background:var(--card);
  border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow),inset 0 0 70px rgba(60,42,18,.20);
  cursor:grab;scrollbar-width:none;-ms-overflow-style:none}
.map-viewport::-webkit-scrollbar{display:none}     /* hidden everywhere; pan by drag/touch */
.map-viewport.dragging{cursor:grabbing}
.map-canvas{position:relative;width:2449px;height:830px}
.map-canvas img{display:block;width:2449px;height:830px;user-select:none;-webkit-user-drag:none}

/* compass rose, pinned to the plate's corner (decorative SVG, styled via classes) */
.compass{position:absolute;top:14px;right:14px;width:54px;height:54px;z-index:5;
  pointer-events:none;filter:drop-shadow(var(--shadow-sm))}
.compass-face{fill:rgba(251,246,236,.88);stroke:var(--line);stroke-width:1.3}
.compass-n{fill:var(--brick)}
.compass-s{fill:var(--ink-faint)}
/* The aerial is rotated ~46.9deg: in geo.py's affine transform true north (the +latitude
   direction) maps to pixel vector (+386538,-362238) = 46.9deg clockwise of screen-up. Turn
   the needles to match; the upright "N" label is repositioned to the new tip in the template.
   Re-derive this angle if app/static/img/neighborhood.png (and the GCP fit) is replaced. */
.compass-n,.compass-s{transform:rotate(46.9deg);transform-origin:center;transform-box:view-box}
.compass-lbl{fill:var(--brick);font-family:"Spline Sans Mono",monospace;font-size:11px;
  font-weight:700;text-anchor:middle;dominant-baseline:middle}

/* survey markers, colour-coded by household type (CSS attribute selectors → no JS) */
.door{position:absolute;transform:translate(-50%,-50%);width:24px;height:30px;padding:0;
  border:0;background:none;cursor:pointer;z-index:2;line-height:0}
.door-pin{display:block;width:16px;height:16px;margin:0 auto;border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);background:var(--slate);border:2.5px solid #fff;
  box-shadow:0 2px 5px -1px rgba(40,28,12,.5);transition:transform .12s,background .12s,filter .12s}
.door[data-rental="1"] .door-pin{background:var(--brass)}
.door[data-vacant="1"] .door-pin{background:var(--ink)}
.door:hover .door-pin{filter:brightness(1.1)}
/* Keep pins anchored. The theme's global `button:hover/active{transform:translateY(-1px)}`
   would otherwise replace the centering translate and make pins jump on hover/click. */
.door,.door:hover,.door:active,.door:focus{transform:translate(-50%,-50%)}
.door:focus-visible{outline:2px solid var(--brick);outline-offset:2px;border-radius:4px}
.door.is-selected{z-index:3}
/* must follow the data-* colour rules so the selected pin wins */
.door.is-selected .door-pin{background:var(--brick);transform:rotate(-45deg) scale(1.4);
  box-shadow:0 3px 8px -2px rgba(140,54,32,.5)}

#you-are-here{position:absolute;transform:translate(-50%,-50%);width:18px;height:18px;
  border-radius:50%;background:var(--sage);border:3px solid #fff;z-index:4;pointer-events:none;
  animation:youPulse 2.2s var(--ease) infinite}
@keyframes youPulse{0%,100%{box-shadow:0 0 0 5px rgba(86,107,70,.32)}
  50%{box-shadow:0 0 0 11px rgba(86,107,70,.10)}}

/* "find my location" — small crosshair control overlapping the plate's bottom-right */
.locate-fab{position:absolute;right:14px;bottom:14px;z-index:6;width:46px;height:46px;
  border-radius:50%;padding:0;font-size:1.4rem;line-height:1;display:flex;align-items:center;
  justify-content:center;color:var(--brick);background:linear-gradient(var(--card-edge),var(--card));
  border:1.5px solid var(--line);box-shadow:var(--shadow)}
.locate-fab:hover{border-color:var(--brick);background:var(--brick-soft)}
.locate-status-float{position:absolute;right:68px;bottom:24px;z-index:6;max-width:210px;
  font-family:"Spline Sans Mono",monospace;font-size:.72rem;color:var(--ink-soft);
  background:rgba(251,246,236,.92);border:1px solid var(--line-soft);border-radius:6px;padding:.25rem .55rem}
.locate-status-float:empty{display:none}

/* selected household: a floating "field card" over the plate */
.door-card{position:absolute;left:16px;bottom:16px;z-index:6;max-width:290px;
  display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:14px;
  background:linear-gradient(var(--card-edge),var(--card));border:1.5px solid var(--line);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:9px 12px;
  animation:cardRise .2s var(--ease)}
@keyframes cardRise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.door-card h2{grid-column:1 / -1;font-family:"Fraunces",serif;font-weight:600;font-size:1rem;margin:0 0 2px;line-height:1.15}
.door-card h2 a{color:var(--ink);text-decoration:none}
.door-card h2 a:hover{color:var(--brick)}
.door-card p{grid-column:1;margin:0;color:var(--ink-soft);font-family:"Spline Sans Mono",monospace;
  font-size:.76rem;line-height:1.3}
.door-card .dc-person{display:block}
.door-card .dc-meta{display:block;margin-top:1px;color:var(--ink-faint);font-size:.7rem;letter-spacing:.02em}
.door-more{grid-column:2;justify-self:end;white-space:nowrap;font-family:"Spline Sans Mono",monospace;
  font-weight:600;font-size:.74rem;letter-spacing:.03em;color:var(--brick);text-decoration:none}
/* rentals flagged by the brass pin colour instead of the word "rental"; darken text for contrast */
.door-card.is-rental{background:linear-gradient(#cda159,var(--brass));border-color:#9c7634}
.door-card.is-rental h2 a,.door-card.is-rental p,.door-card.is-rental .door-more{color:#241f15}
.door-card.is-rental .dc-meta{color:#3f3618}
.door-card .dc-owed{display:block;margin-top:2px;font-weight:700;color:var(--brick)}
.door-card.is-rental .dc-owed{color:#5e2417}   /* darker red for contrast on the brass card */
.door-more:hover{text-decoration:underline}
@media (max-width:820px){ .map-viewport{height:60vh} .map-legend{margin-left:0}
  .door-card{left:8px;right:8px;bottom:8px;max-width:none} }

/* ───────── owner registry ───────── */
table.registry td{vertical-align:top;font-size:.9rem}
table.registry .addr-sub{display:block;font-size:.72rem;color:var(--ink-faint)}
.empty-note{padding:1rem 0;color:var(--ink-soft)}
.empty-note code{background:var(--card);padding:.1rem .35rem;border-radius:.25rem}

/* hidden must win over display:grid/flex (CSP-safe JS toggles [hidden]) */
[hidden] { display: none !important; }

/* ============================================================
   Dues — "Annual Assessment" treasury instrument  (CSP-safe)
   Treasury counterpart to the deed/recorded-instrument pages:
   brick tone, mono kickers, Fraunces numerals, a wax-seal that
   carries the amount, and a stamped PAID seal on the receipt.
   ============================================================ */
.dues-instrument{max-width:600px}

/* ── masthead: kicker + title, with the assessment seal ── */
.dues-mast{display:flex;justify-content:space-between;align-items:flex-start;
  gap:20px;flex-wrap:wrap;margin:6px 0 26px}
.dues-kicker{margin:0 0 6px;font-family:"Spline Sans Mono",monospace;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--brick)}
.dues-mast h1{font-size:2.4rem}

/* ── wax seal carrying the dues amount (echoes .deed-seal) ── */
.dues-seal{flex:none;width:104px;height:104px;border-radius:50%;background:var(--card);
  border:2px solid var(--brick);color:var(--brick-deep);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;transform:rotate(-7deg);
  box-shadow:inset 0 0 0 4px var(--card),inset 0 0 0 5px var(--brick-edge),var(--shadow-sm)}
.dues-seal b{font-family:"Fraunces",serif;font-weight:600;font-size:1.5rem;line-height:1;
  font-variant-numeric:lining-nums}
.dues-seal i{font-family:"Spline Sans Mono",monospace;font-style:normal;font-size:.52rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--brick)}

/* ── step tags inside the picker legends ── */
.pick-step legend .step-tag{display:inline-block;margin-right:9px;padding:2px 8px;
  font-family:"Spline Sans Mono",monospace;font-weight:700;font-size:.6rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--brick);background:var(--brick-soft);
  border:1px solid var(--brick-edge);border-radius:6px;vertical-align:middle}

.dues-houses-wrap{margin-top:20px}

/* ── contact form: remittance slip on card stock ── */
.dues-confirm{margin:-6px 0 20px;font-size:1.02rem;color:var(--ink-soft)}
.dues-confirm strong{color:var(--ink);font-family:"Fraunces",serif;font-weight:600}
.dues-contact{display:flex;flex-direction:column;gap:.35rem;max-width:460px;
  background:var(--card);padding:24px;border:1.5px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.dues-contact label{margin-top:.6rem}

/* ── note as a recorded-instrument footnote ── */
.dues-note{margin-top:24px;padding-left:14px;border-left:2px solid var(--line);
  font-family:"Spline Sans Mono",monospace;font-size:.74rem;letter-spacing:.01em;
  color:var(--ink-faint)}

/* ── receipt: stamped PAID seal ── */
.dues-receipt{position:relative}
.dues-receipt .dues-kicker{margin-top:4px}
.dues-receipt-body{max-width:46ch;color:var(--ink-soft);line-height:1.6}
.dues-paid-stamp{position:absolute;top:-4px;right:4px;width:126px;height:126px;border-radius:50%;
  border:3px double var(--sage);color:var(--sage);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:3px;transform:rotate(-12deg);
  box-shadow:inset 0 0 0 5px var(--card),inset 0 0 0 6px var(--sage-edge)}
.dues-paid-stamp b{font-family:"Fraunces",serif;font-weight:600;font-size:2.05rem;letter-spacing:.04em}
.dues-paid-stamp i{font-family:"Spline Sans Mono",monospace;font-style:normal;font-size:.56rem;
  letter-spacing:.2em;text-transform:uppercase}

/* ── motion: a single composed reveal, opt-in to motion only ── */
@keyframes dues-rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes dues-seal-press{0%{opacity:0;transform:rotate(-7deg) scale(1.5)}
  60%{opacity:1}100%{opacity:1;transform:rotate(-7deg) scale(1)}}
@keyframes dues-paid-press{0%{opacity:0;transform:rotate(-12deg) scale(1.7)}
  55%{opacity:1}100%{opacity:1;transform:rotate(-12deg) scale(1)}}
@media (prefers-reduced-motion:no-preference){
  .dues-instrument .dues-mast{animation:dues-rise .4s var(--ease) both}
  .dues-instrument .dues-pick,
  .dues-instrument .dues-confirm,
  .dues-instrument .dues-receipt-body{animation:dues-rise .4s var(--ease) both .08s}
  .dues-seal{animation:dues-seal-press .5s var(--ease) both .12s}
  .dues-houses:not([hidden]){animation:dues-rise .26s var(--ease) both}
  .dues-paid-stamp{animation:dues-paid-press .55s var(--ease) both .15s}
}

/* ── narrow screens: seal/stamp step down, never overlap the title ── */
@media (max-width:560px){
  /* keep the seal in the top-right beside the title (don't wrap it below) */
  .dues-mast{gap:14px;flex-wrap:nowrap}
  .dues-mast-title{flex:1 1 auto;min-width:0}
  .dues-mast h1{font-size:1.55rem}
  .dues-seal{width:84px;height:84px}
  .dues-seal b{font-size:1.25rem}
  .dues-paid-stamp{position:static;margin:0 0 18px;width:108px;height:108px}
}

/* ───────── roster (continuous table of expandable rows) ───────── */
/* shared column grid for the header + every row's summary */
.roster-sheet{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);
  box-shadow:var(--shadow-sm);overflow:hidden}
/* the column grid lives on an inner wrapper, NOT on <summary> — gridding the summary
   itself makes the disclosure marker a phantom 4th grid item. Header + cols share the
   grid so columns align; side tracks are fixed (rem) so each row's 1fr resolves equally. */
.roster-head,.roster-cols{display:grid;grid-template-columns:14rem minmax(0,1fr) 10rem;
  gap:.35rem 1rem;align-items:start}
.roster-head{padding:.5rem .85rem;font-family:"Public Sans";font-size:.66rem;font-weight:700;
  letter-spacing:.11em;text-transform:uppercase;color:var(--ink-faint);background:var(--paper-2);
  border-bottom:1px solid var(--line)}
.roster-head span:last-child{justify-self:end}

.roster-row{margin-top:0;border-bottom:1px solid var(--line-soft)}
.roster-row:last-child{border-bottom:0}
/* fully override the app-wide <details>/summary chrome (inline-flex pill, paper bg, border,
   brick text, ✎ pencil, open margins) so rows read as flush, full-width table rows */
.roster-row summary{display:block;cursor:pointer;list-style:none;padding:.5rem .85rem;
  margin:0;border:0;border-radius:0;background:transparent;color:inherit;
  font-weight:400;font-size:1rem;gap:0;user-select:auto;transition:background .15s}
.roster-row summary::before{content:none}
.roster-row summary::-webkit-details-marker{display:none}
.roster-row summary::marker{content:"";font-size:0}
.roster-row summary:hover{background:var(--paper-2);border-color:transparent}
details[open].roster-row > summary{margin-bottom:0;background:var(--paper-2);
  border-color:transparent;color:inherit}

/* address cell: chevron + name, with lot · count on a second line */
.roster-main{min-width:0}
.roster-addr{font-weight:700;display:block}
.roster-addr::before{content:"›";display:inline-block;margin-right:.45rem;color:var(--ink-faint);
  transition:transform .18s var(--ease)}
details[open].roster-row .roster-addr::before{transform:rotate(90deg)}
.roster-sub{color:var(--ink-soft);font-size:.8rem;font-family:"Spline Sans Mono",monospace;letter-spacing:.01em}
/* residents + contact, the middle column */
.roster-people{min-width:0;color:var(--ink-soft);font-size:.88rem}
.roster-people .rp{display:block;padding:.05rem 0}
.roster-people em{color:var(--ink-faint);font-style:normal;font-size:.8rem}
/* status tags, right-aligned column */
.roster-flags{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end;text-align:right;justify-self:end}
/* expandable edit area — "index-card" contact sheet, ledger-flavored */
.contact-edit{padding:.55rem 1rem .9rem;border-top:1px solid var(--line);
  background:linear-gradient(var(--paper-2),var(--paper))}
details[open] > .contact-edit{animation:contactReveal .22s var(--ease)}
@keyframes contactReveal{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}

.contact-person{padding:.7rem 0;border-bottom:1px dashed var(--line)}
.contact-person:last-of-type{border-bottom:0}
.rp-head{display:flex;align-items:baseline;gap:.55rem;margin-bottom:.45rem}
.rp-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.04rem;color:var(--ink)}
.rp-role{font-family:"Spline Sans Mono",monospace;font-size:.58rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line);border-radius:1rem;padding:.06rem .5rem}

/* fields hang off a brass margin rule, like notes in a ledger */
.rp-fields{display:flex;flex-direction:column;gap:.3rem;padding-left:.85rem;border-left:2px solid var(--brass-edge)}
.contact-edit form.field{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin:0}
.field-lab{flex:0 0 3.4rem;font-family:"Spline Sans Mono",monospace;font-size:.58rem;font-weight:600;
  letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint)}
.contact-edit form.field input[type=email]{width:auto;flex:1 1 14rem;margin:0}
.contact-edit form.field input[type=text]{width:auto;flex:1 1 9rem;margin:0;
  font-family:"Spline Sans Mono",monospace;font-size:.84rem}
.contact-edit form.field select{width:auto;margin:0;font-size:.8rem;padding:.32rem .4rem}
.field .prim{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--ink-soft);font-weight:500}
.field .prim input{width:auto;margin:0;accent-color:var(--brick)}
.contact-edit form.field.add{opacity:.72}
.contact-edit form.field.add:focus-within{opacity:1}

/* quiet Save that lights up only when you're editing that field */
.field-save{font-size:.74rem;padding:.28rem .7rem;color:var(--ink-soft);
  background:var(--card);border:1px solid var(--line);box-shadow:none}
.field-save:hover{filter:none;border-color:var(--ink-faint)}
form.field:focus-within .field-save{color:#fff;border-color:transparent;
  background:linear-gradient(150deg,var(--brick),var(--brick-deep))}

/* a phone and its delete share one line */
.phone-row{display:flex;align-items:center;gap:.4rem}
.phone-row .field{flex:1 1 auto}
button.x{font-size:1.05rem;line-height:1;padding:.12rem .42rem;color:var(--ink-faint);
  background:none;border:1px solid var(--line);box-shadow:none}
button.x:hover{filter:none;transform:none;color:var(--brick);border-color:var(--brick);background:var(--brick-soft)}

/* read-only (viewers): label/value grid */
.rp-fields.readonly{display:grid;grid-template-columns:3.4rem 1fr;gap:.15rem .45rem;border-left-color:var(--line)}
.rp-val{font-family:"Spline Sans Mono",monospace;font-size:.82rem;color:var(--ink-soft)}

.roster-manage{margin-top:.7rem}
.roster-manage a{font-family:"Spline Sans Mono",monospace;font-size:.74rem;letter-spacing:.04em;color:var(--brick)}
.tag.vacant{color:var(--ink-soft);border-color:var(--line);background:transparent}

/* ───────── property record (dossier) ───────── */
.back-link{display:inline-block;font-family:"Spline Sans Mono",monospace;font-size:.72rem;
  letter-spacing:.04em;color:var(--ink-soft);text-decoration:none;margin:0 0 .5rem}
.back-link:hover{color:var(--brick)}
.stamps{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:.8rem}
.stamp{font-family:"Spline Sans Mono",monospace;font-size:.66rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--brick);background:var(--brick-soft);
  border:1.5px solid var(--brick-edge);border-radius:5px;padding:.28rem .6rem;transform:rotate(-1.2deg)}
/* left panel: tidier edit form */
.prop-form .check-group{display:flex;gap:1.4rem;flex-wrap:wrap}
.prop-form .flag-field{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.prop-form .flag-field input[type=text]{flex:1 1 12rem;width:auto;margin:0}
.prop-form .checkrow{font-weight:500;color:var(--ink-soft)}
/* residents: summary head extras */
.rp-name .pri{color:var(--brass)}
.rp-name .captain{font-size:.72rem;font-weight:600;color:var(--brass);border:1px solid var(--brass);border-radius:.6rem;padding:.05rem .4rem;margin-left:.35rem;vertical-align:middle;white-space:nowrap}
.prim .hint{color:var(--ink-faint);font-weight:400;font-size:.72rem}
.rp-contact{font-family:"Spline Sans Mono",monospace;font-size:.78rem;color:var(--ink-soft)}
.rp-phones{list-style:none;margin:.3rem 0 .45rem;padding:0;display:flex;flex-wrap:wrap;gap:.25rem 1rem}
.rp-phones li{font-family:"Spline Sans Mono",monospace;font-size:.8rem;color:var(--ink-soft)}
.rp-phones em{font-style:normal;color:var(--ink-faint);font-size:.72rem}
/* multi-field resident edit form (reuses .field-lab / .field-save / .prim tokens) */
.resident-form{display:flex;flex-direction:column;gap:.4rem;margin:0 0 .3rem}
.contact-edit .field-row{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.contact-edit .field-row input[type=text],.contact-edit .field-row input[type=email]{width:auto;flex:1 1 13rem;margin:0}
.contact-edit .field-row select{width:auto;margin:0;font-size:.84rem}
.resident-form .prim{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--ink-soft);font-weight:500}
.resident-form .prim input{width:auto;margin:0;accent-color:var(--brick)}
.resident-form:focus-within .field-save{color:#fff;border-color:transparent;
  background:linear-gradient(150deg,var(--brick),var(--brick-deep))}
.del-resident{margin-top:.2rem}
button.x-link{font-size:.74rem;color:var(--ink-faint);background:none;border:0;box-shadow:none;
  padding:.2rem 0;text-decoration:underline}
button.x-link:hover{filter:none;transform:none;color:var(--brick)}
.rp-empty{padding:.5rem 0}

/* roster mobile — placed AFTER the base .roster-* rules so these win the cascade (equal
   specificity => later source position decides). Narrows the address column, hides the
   street-type suffix (Cir/Dr), shrinks type; the middle residents/contact column keeps the rest. */
@media (max-width:560px){
  .roster-head,.roster-cols{grid-template-columns:minmax(0,8rem) minmax(0,1fr) auto;gap:.3rem .55rem}
  .roster-row summary{padding:.5rem .6rem}
  .roster-head{padding:.5rem .6rem;font-size:.6rem;letter-spacing:.06em}
  .addr-suffix{display:none}
  .roster-addr{font-size:.92rem}
  .roster-sub{font-size:.72rem}
  .roster-people{font-size:.82rem}
}

/* ── my-street / board pages ─────────────────────────────── */
.home-card { border: 1px solid var(--border, #ddd); border-radius: 8px;
             padding: .75rem 1rem; margin: .75rem 0; }
.home-card h2 { margin: 0 0 .35rem; font-size: 1.05rem; }
.contact-list { list-style: none; margin: 0; padding: 0; }
.contact-list li { padding: .25rem 0; }
.street-list { columns: 2; list-style: none; padding: 0; }

form.inline { display: inline; }

/* ============================================================
   Public front page — "Plat of Chimney Hill"  (CSP-safe)
   Title-page treatment of the deed-paper system: centered
   letterpress masthead, self-drawing roofline with chimney
   smoke, four tone-keyed record cards.
   ============================================================ */
.plat{max-width:920px;margin:0 auto}

/* ── masthead ── */
.plat-mast{text-align:center;padding-top:26px}
.plat-kicker{margin:0 0 14px;font-family:"Spline Sans Mono",monospace;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--brick);
  animation:plat-rise .65s var(--ease) .1s both}
.plat-title{font-family:"Fraunces",serif;font-weight:580;letter-spacing:-.022em;
  font-size:clamp(3rem,8.5vw,4.7rem);line-height:.98;margin:0;
  animation:plat-rise .65s var(--ease) .2s both}
.plat-sub{margin:10px 0 0;font-family:"Fraunces",serif;font-style:italic;font-weight:430;
  font-size:1.28rem;color:var(--ink-soft);display:flex;align-items:center;
  justify-content:center;gap:14px;animation:plat-rise .65s var(--ease) .3s both}
.plat-sub::before,.plat-sub::after{content:"";height:1.5px;width:54px;
  background:linear-gradient(90deg,transparent,var(--line));flex:none}
.plat-sub::after{background:linear-gradient(90deg,var(--line),transparent)}
.plat-intro{margin:18px auto 0;max-width:52ch;color:var(--ink-soft);font-size:1.02rem;
  line-height:1.6;animation:plat-rise .65s var(--ease) .4s both}

/* ── roofline: strokes draw on load, smoke drifts forever ── */
.plat-roofline{max-width:680px;margin:10px auto 6px;
  animation:plat-rise .65s var(--ease) .5s both}
.plat-roofline svg{display:block;width:100%;height:auto}
.rl-line{fill:none;stroke:var(--ink-soft);stroke-width:2.2;stroke-linecap:round;
  stroke-linejoin:round;stroke-dasharray:1;stroke-dashoffset:1;
  animation:rl-draw 1s var(--ease) forwards}
.rl-base{stroke:var(--ink-faint);stroke-width:1.6;animation-delay:.5s}
.rl-line-1{animation-delay:.8s}
.rl-line-2{animation-delay:1s}
.rl-line-3{animation-delay:1.25s}
@keyframes rl-draw{to{stroke-dashoffset:0}}
.rl-puff{fill:none;stroke:var(--ink-faint);stroke-width:1.6;opacity:0;
  transform-box:fill-box;transform-origin:center;
  animation:rl-drift 5.4s ease-in-out infinite}
.rl-puff-1{animation-delay:2s}
.rl-puff-2{animation-delay:3.8s}
.rl-puff-3{animation-delay:5.6s}
@keyframes rl-drift{
  0%{opacity:0;transform:translateY(7px) scale(.65)}
  30%{opacity:.7}
  100%{opacity:0;transform:translate(6px,-24px) scale(1.2)}}

/* ── record cards ── */
.plat-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:26px}
.plat-card{--tone:var(--brick);--tone-soft:var(--brick-soft);--tone-edge:var(--brick-edge);
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(180deg,var(--card-edge),var(--card));
  border:1.5px solid var(--line);border-radius:var(--radius);
  padding:20px 24px 20px 28px;box-shadow:var(--shadow-sm);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s;
  animation:plat-rise .65s var(--ease) both}
.plat-card:nth-child(1){animation-delay:.55s}
.plat-card:nth-child(2){animation-delay:.65s}
.plat-card:nth-child(3){animation-delay:.75s}
.plat-card:nth-child(4){animation-delay:.85s}
.plat-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:var(--tone);transition:width .18s var(--ease)}
.plat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);
  border-color:var(--tone-edge)}
.plat-card:hover::before{width:9px}
.plat-card--brass{--tone:var(--brass);--tone-soft:var(--brass-soft);--tone-edge:var(--brass-edge)}
.plat-card--brick{--tone:var(--brick);--tone-soft:var(--brick-soft);--tone-edge:var(--brick-edge)}
.plat-card--slate{--tone:var(--slate);--tone-soft:var(--slate-soft);--tone-edge:var(--slate-edge)}
.plat-card--sage{--tone:var(--sage);--tone-soft:var(--sage-soft);--tone-edge:var(--sage-edge)}
.plat-tag{margin:0 0 6px;font-family:"Spline Sans Mono",monospace;font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--tone)}
.plat-card h2{font-family:"Fraunces",serif;font-weight:600;font-size:1.5rem;
  line-height:1.12;margin:0 0 8px;letter-spacing:-.01em}
.plat-card>p{margin:0 0 14px;color:var(--ink-soft);font-size:.96rem;line-height:1.55}
.plat-links{display:flex;flex-wrap:wrap;gap:10px;margin:auto 0 0}
.plat-links a{text-decoration:none;font-weight:600;font-size:.88rem;
  padding:8px 15px;border-radius:999px;border:1.5px solid var(--tone-edge);
  background:var(--tone-soft);color:var(--ink);
  transition:background .15s,color .15s,border-color .15s}
.plat-links a:first-child{background:var(--tone);border-color:var(--tone);color:#fff}
.plat-links a::after{content:"→";display:inline-block;margin-left:7px;
  transition:transform .18s var(--ease)}
.plat-links a:hover{background:var(--ink);border-color:var(--ink);color:var(--card-edge)}
.plat-links a:hover::after{transform:translateX(3px)}

/* ── footer line ── */
.plat-foot{margin-top:44px;padding-top:18px;border-top:1.5px solid var(--line-soft);
  animation:plat-rise .65s var(--ease) 1s both}
.plat-foot p{margin:0;text-align:center;font-family:"Spline Sans Mono",monospace;
  font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}

@keyframes plat-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

@media (min-width:740px){
  .plat-grid{grid-template-columns:1fr 1fr;gap:20px 22px}
  .plat-card:nth-child(even){margin-top:18px}
  .plat-card:nth-child(3){margin-top:-18px}
}
@media (prefers-reduced-motion:reduce){
  .plat-kicker,.plat-title,.plat-sub,.plat-intro,.plat-roofline,.plat-card,.plat-foot{
    animation:none}
  .rl-line{animation:none;stroke-dashoffset:0}
  .rl-puff{animation:none;opacity:.45}
}
