/* ==========================================================================
   The Register — PCMC TDR Pool Portal · app.css
   A certified ledger, not a SaaS dashboard.
   Part 1 ports the prototype (design/prototype/dashboard.html) verbatim — that
   markup IS the design language. Part 2 extends it into a reusable system
   (buttons, fields, chips, tabs, kanban, definition rows, empty states,
   generic tables, role switch, responsive rail). Do not restyle Part 1.
   ========================================================================== */

/* ---- tokens ------------------------------------------------------------- */
:root{
  --ink:#13251E; --ink-2:#3B4A44; --paper:#EEF2F0; --card:#FBFCFB;
  --rule:#D5DEDF; --rule-2:#C2CDC8; --seal:#B23A2E; --brass:#9A7B3F;
  --avail:#2F6B4F; --wash:#E4EAE7;
  --seal-2:#933024; --avail-wash:rgba(47,107,79,.10); --res-wash:rgba(154,123,63,.12); --seal-wash:rgba(178,58,46,.09);
  --sans:'Public Sans',system-ui,sans-serif; --serif:'Fraunces',Georgia,serif; --mono:'IBM Plex Mono',monospace;
  --shadow:0 1px 2px rgba(19,37,30,.04),0 8px 24px rgba(19,37,30,.06);
}
*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.5}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.eyebrow{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
a{color:inherit}
.brass{color:var(--brass)}
[hidden]{display:none!important}

/* ==========================================================================
   PART 1 — ported from the prototype
   ========================================================================== */

/* shell */
.shell{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.rail{background:var(--ink);color:#DCE6E0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:22px 0;overflow-y:auto}
.brand{display:flex;gap:11px;align-items:center;padding:0 20px 20px}
.brand .seal{flex:none}
.brand b{font-family:var(--serif);font-weight:500;font-size:15px;color:#fff;line-height:1.15;letter-spacing:.01em}
.brand span{display:block;font-size:9.5px;letter-spacing:.16em;color:#7E938A;text-transform:uppercase;margin-top:3px}
nav{margin-top:14px;padding:0 12px;display:flex;flex-direction:column;gap:1px}
nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:7px;color:#AFC1B8;text-decoration:none;font-weight:500;font-size:13.5px;cursor:pointer}
nav a .g{width:15px;text-align:center;opacity:.8;font-size:13px}
nav a:hover{background:rgba(255,255,255,.05);color:#EAF1ED}
nav a.on{background:#EEF2F0;color:var(--ink);font-weight:600}
nav a.on .g{opacity:1}
nav a .badge{margin-left:auto}
.rail .sep{margin:14px 20px 10px;font-size:9.5px;letter-spacing:.16em;color:#63776E;text-transform:uppercase}
.me{margin-top:auto;padding:14px 20px 2px;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:11px;align-items:center}
.me .av{width:32px;height:32px;border-radius:50%;background:var(--brass);color:#231a08;display:grid;place-items:center;font-weight:700;font-size:12px;flex:none}
.me b{font-size:12.5px;color:#EAF1ED;font-weight:600;display:block;line-height:1.2}
.me span{font-size:10.5px;color:#7E938A}

/* topbar */
main{min-width:0}
.content{min-width:0;display:flex;flex-direction:column}
#view{min-width:0}
.top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 34px;border-bottom:1px solid var(--rule);background:rgba(238,242,240,.86);backdrop-filter:blur(6px);position:sticky;top:0;z-index:15}
.crumb{font-size:12.5px;color:var(--ink-2)}
.crumb b{color:var(--ink);font-weight:600}
.asof{display:flex;align-items:center;gap:16px}
.asof .st{font-size:11px;color:var(--ink-2)}
.asof .st b{color:var(--ink);font-weight:600}
.pill{font-size:11px;font-weight:600;letter-spacing:.02em;padding:5px 11px;border:1px solid var(--rule-2);border-radius:100px;color:var(--ink-2);background:var(--card);white-space:nowrap}

.wrap{padding:30px 34px 60px;max-width:1120px}

/* certified header */
.cert{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:26px 30px 24px;position:relative;overflow:hidden}
.cert .bigseal{position:absolute;right:-26px;top:-20px;opacity:.05;transform:rotate(-8deg)}
.cert .kick{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.cert h1{font-family:var(--serif);font-weight:500;font-size:26px;letter-spacing:-.01em;margin:0;line-height:1.1}
.cert .rule2{height:0;border-top:2px solid var(--ink);margin:15px 0 3px}
.cert .rule2+.rule2{border-top:1px solid var(--rule-2);margin:0 0 20px}
.figs{display:flex;gap:46px;flex-wrap:wrap;align-items:flex-end}
.fig .l{font-size:11px;color:var(--ink-2);font-weight:600;letter-spacing:.02em;margin-bottom:7px}
.fig .v{font-family:var(--serif);font-weight:500;font-size:40px;line-height:.95;letter-spacing:-.02em;color:var(--brass)}
.fig .v .u{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink-2);letter-spacing:0}
.fig.small .v{font-size:26px;color:var(--ink);font-family:var(--mono);font-weight:600}
.fig .sub{font-size:11px;color:var(--ink-2);margin-top:7px}
.fig .sub .up{color:var(--avail);font-weight:600}

/* section head */
.sec{margin-top:34px;display:flex;align-items:baseline;justify-content:space-between;gap:16px}
.sec .t{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.sec h2{font-family:var(--serif);font-weight:500;font-size:17px;margin:0;letter-spacing:-.01em}
.sec .n{font-size:11px;color:var(--ink-2)}
.sec a.act,.sec .act{font-size:12px;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--brass);padding-bottom:1px;cursor:pointer;background:none;border-left:none;border-right:none;border-top:none}

/* register table */
.reg{margin-top:14px;background:var(--card);border:1px solid var(--rule);border-radius:12px;overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);text-align:right;padding:12px 16px;border-bottom:1px solid var(--rule-2);background:var(--wash)}
thead th.l{text-align:left}
thead th.gut{width:44px;padding:0}
tbody td{padding:14px 16px;border-bottom:1px solid var(--rule);text-align:right;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#F4F7F5}
td.l{text-align:left}
.drc{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--ink)}
.meta{font-size:11px;color:var(--ink-2);margin-top:2px}
.rem{font-weight:600;color:var(--ink)}
.mrp{color:var(--brass);font-weight:600}
.op{color:var(--rule-2);padding:0 2px;font-family:var(--mono)}

/* endorsement gutter + status seals */
.gut{width:44px;padding:0;border-bottom:1px solid var(--rule);position:relative}
.gut::before{content:"";position:absolute;right:0;top:0;bottom:0;border-right:1px solid var(--rule-2)}
.stamp{width:16px;height:16px;border-radius:50%;margin:0 auto;position:relative;border:1.5px solid}
.stamp.avail{border-color:var(--avail)}
.stamp.res{border-color:var(--brass);background:radial-gradient(circle at 50% 50%,var(--brass) 0 46%,transparent 47%)}
.stamp.sold{border-color:var(--seal);background:var(--seal)}
.stamp.sold::after{content:"";position:absolute;inset:3px;border:1px solid rgba(255,255,255,.6);border-radius:50%}

tfoot td{padding:14px 16px;border-top:2px solid var(--ink);font-weight:700}
tfoot .lab{text-align:left;font-family:var(--sans);letter-spacing:.02em;font-size:12px;text-transform:uppercase}
tfoot .mrp{font-size:15px}

/* pipeline stepper */
.pipes{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.pipe{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:18px 20px}
.pipe .hd{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:16px}
.pipe .buyer{font-weight:600;font-size:14px}
.pipe .buyer span{display:block;font-size:11px;color:var(--ink-2);font-weight:400;margin-top:2px}
.pipe .slice{text-align:right;font-family:var(--mono);font-weight:600;font-size:14px;white-space:nowrap}
.pipe .slice span{display:block;font-size:11px;color:var(--brass);font-weight:600}
.steps{display:flex;align-items:center}
.step{flex:1;text-align:center;position:relative}
.step .dot{width:11px;height:11px;border-radius:50%;background:var(--card);border:1.5px solid var(--rule-2);margin:0 auto 8px;position:relative;z-index:2}
.step .lb{font-size:9.5px;letter-spacing:.04em;color:var(--ink-2);text-transform:uppercase;font-weight:600}
.step:not(:last-child)::after{content:"";position:absolute;top:5px;left:50%;width:100%;height:1.5px;background:var(--rule-2);z-index:1}
.step.done .dot{background:var(--ink);border-color:var(--ink)}
.step.done:not(:last-child)::after{background:var(--ink)}
.step.done .lb{color:var(--ink)}
.step.now .dot{background:var(--seal);border-color:var(--seal);box-shadow:0 0 0 4px rgba(178,58,46,.14)}
.step.now .lb{color:var(--seal);font-weight:700}

/* endorsements ledger */
.endo{margin-top:14px;background:var(--card);border:1px solid var(--rule);border-radius:12px}
.endo .row{display:grid;grid-template-columns:96px 1fr 130px 120px;gap:14px;align-items:center;padding:13px 18px;border-bottom:1px solid var(--rule)}
.endo .row:last-child{border-bottom:none}
.endo .row:hover{background:#F4F7F5}
.endo .dt{font-family:var(--mono);font-size:12px;color:var(--ink-2)}
.endo .who{font-size:13px;font-weight:600}
.endo .who span{font-weight:400;color:var(--ink-2)}
.endo .ar{text-align:right;font-family:var(--mono);font-size:13px}
.endo .vl{text-align:right;font-family:var(--mono);font-size:13px;color:var(--brass);font-weight:600}
.foot{margin-top:26px;font-size:11px;color:var(--ink-2);display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ==========================================================================
   PART 2 — extensions (new components, same language)
   ========================================================================== */

/* role switch in the topbar */
.roleswitch{display:inline-flex;align-items:center;gap:8px}
.roleswitch label{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
select.role{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--rule-2);border-radius:100px;padding:6px 30px 6px 13px;cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'><path d='M1 1l4 4 4-4' fill='none' stroke='%233B4A44' stroke-width='1.4'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center}

/* hamburger (mobile rail) */
.railtoggle{display:none;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--rule-2);border-radius:8px;background:var(--card);color:var(--ink);cursor:pointer;font-size:15px}
.scrim{display:none;position:fixed;inset:0;background:rgba(19,37,30,.38);z-index:30}
.scrim.open{display:block}

/* page header for non-certified screens */
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap}
.pagehead h1{font-family:var(--serif);font-weight:500;font-size:24px;letter-spacing:-.01em;margin:0;line-height:1.12}
.pagehead .lead{font-size:12.5px;color:var(--ink-2);margin-top:6px;max-width:60ch}
.pagehead .actions{display:flex;gap:10px;align-items:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:13px;font-weight:600;line-height:1;color:var(--ink);background:var(--card);border:1px solid var(--rule-2);border-radius:9px;padding:9px 15px;cursor:pointer;text-decoration:none;transition:background .12s,border-color .12s,box-shadow .12s;white-space:nowrap}
.btn:hover{background:var(--wash);border-color:var(--ink-2)}
.btn:active{transform:translateY(.5px)}
.btn .g{font-size:14px;opacity:.85}
.btn.sm{padding:6px 11px;font-size:12px;border-radius:8px}
.btn.lg{padding:11px 20px;font-size:14px}
.btn-seal{background:var(--seal);border-color:var(--seal);color:#fff}
.btn-seal:hover{background:var(--seal-2);border-color:var(--seal-2)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--wash);color:var(--ink)}
.btn[disabled],.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* generic panel + card */
.panel{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:22px 24px}
.panel+.panel{margin-top:14px}
.card{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:16px 18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* stat tiles (for screens without the .cert header) */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-top:14px}
.stat{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:16px 18px}
.stat .l{font-size:11px;color:var(--ink-2);font-weight:600;letter-spacing:.02em;margin-bottom:8px}
.stat .v{font-family:var(--mono);font-weight:600;font-size:23px;letter-spacing:-.02em;color:var(--ink)}
.stat.brass .v{color:var(--brass)}
.stat.serif .v{font-family:var(--serif);font-weight:500;font-size:30px}
.stat .sub{font-size:11px;color:var(--ink-2);margin-top:6px}

/* form fields */
.grid-in{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px}
.grid-in .span-2{grid-column:1 / -1}
.field{display:flex;flex-direction:column;gap:6px}
.field>label,.field .lab{font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--ink-2)}
.field>label .req{color:var(--seal);margin-left:2px}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--card);border:1px solid var(--rule-2);border-radius:9px;padding:10px 12px;width:100%;transition:border-color .12s,box-shadow .12s}
.field textarea{min-height:84px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--seal);box-shadow:0 0 0 3px rgba(178,58,46,.12)}
.field input::placeholder{color:#9AA9A2}
.field.num input,input.num,.field .num input{font-family:var(--mono);font-variant-numeric:tabular-nums}
.field .hint{font-size:11px;color:var(--ink-2)}
.field .hint.warn{color:var(--seal);font-weight:600}
.field.inline{flex-direction:row;align-items:center;gap:10px}
.inputgroup{display:flex;align-items:stretch}
.inputgroup input{border-radius:9px 0 0 9px}
.inputgroup .unit{display:flex;align-items:center;padding:0 12px;border:1px solid var(--rule-2);border-left:none;border-radius:0 9px 9px 0;background:var(--wash);color:var(--ink-2);font-size:12px;font-weight:600}

/* chips + status pills */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.01em;color:var(--ink-2);background:var(--card);border:1px solid var(--rule-2);border-radius:100px;padding:4px 11px;white-space:nowrap}
.chip .stamp{width:11px;height:11px}
.pillstat{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:100px;padding:4px 10px}
.pillstat::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;flex:none}
.pillstat.avail{color:var(--avail);background:var(--avail-wash)}
.pillstat.res{color:var(--brass);background:var(--res-wash)}
.pillstat.sold{color:var(--seal);background:var(--seal-wash)}
.pillstat.muted{color:var(--ink-2);background:var(--wash)}
.tag{display:inline-flex;align-items:center;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);background:var(--wash);border-radius:5px;padding:3px 8px}
.tag.slum{color:var(--brass);background:var(--res-wash)}

/* tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--rule-2);margin-top:8px}
.tab{appearance:none;border:none;background:none;font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink-2);padding:10px 15px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--ink);border-bottom-color:var(--brass)}

/* kanban board */
.kanban{display:grid;grid-template-columns:repeat(5,minmax(210px,1fr));gap:14px;margin-top:14px}
.col{background:rgba(228,234,231,.5);border:1px solid var(--rule);border-radius:12px;padding:12px 12px 6px;min-width:0}
.col .colhd{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 12px}
.col .colhd .t{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.col .colhd .n{font-size:11px;font-weight:600;color:var(--ink-2);background:var(--card);border:1px solid var(--rule-2);border-radius:100px;padding:1px 8px}
.dealcard{background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:12px 13px;margin-bottom:10px;cursor:pointer;transition:border-color .12s,box-shadow .12s}
.dealcard:hover{border-color:var(--rule-2);box-shadow:var(--shadow)}
.dealcard .buyer{font-size:13.5px;font-weight:600;line-height:1.2}
.dealcard .meta{font-size:11px;color:var(--ink-2);margin-top:3px}
.dealcard .cardft{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-top:11px}
.dealcard .slice{font-family:var(--mono);font-weight:600;font-size:13px}
.dealcard .slice .u{color:var(--brass)}
.dealcard .no{font-family:var(--mono);font-size:10.5px;color:var(--ink-2)}

/* definition list (deal / member detail) */
.deflist{background:var(--card);border:1px solid var(--rule);border-radius:12px;overflow:hidden}
.def{display:grid;grid-template-columns:220px 1fr;gap:16px;padding:12px 18px;border-bottom:1px solid var(--rule)}
.def:last-child{border-bottom:none}
.def .k{font-size:12.5px;color:var(--ink-2)}
.def .v{font-size:13px;color:var(--ink);font-weight:500}
.def .v.num{font-weight:600}
.def .v.mrp{color:var(--brass);font-weight:600}

/* empty state */
.empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:52px 24px;color:var(--ink-2)}
.empty .seal{opacity:.5;margin-bottom:14px}
.empty h3{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--ink);margin:0 0 6px}
.empty p{font-size:12.5px;max-width:42ch;margin:0 0 16px}

/* toolbar / filters */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:16px}
.toolbar .spacer{flex:1 1 auto}
.search{position:relative;display:inline-flex;align-items:center}
.search input{font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--card);border:1px solid var(--rule-2);border-radius:100px;padding:8px 14px 8px 32px;min-width:220px}
.search input:focus{outline:none;border-color:var(--seal);box-shadow:0 0 0 3px rgba(178,58,46,.12)}
.search .ic{position:absolute;left:12px;color:var(--ink-2);font-size:12px;pointer-events:none}

/* small note / callout */
.note{display:flex;gap:10px;align-items:flex-start;background:var(--wash);border:1px solid var(--rule);border-left:3px solid var(--brass);border-radius:8px;padding:12px 14px;font-size:12px;color:var(--ink-2)}
.note.seal{border-left-color:var(--seal)}
.note b{color:var(--ink)}

/* misc utilities */
.muted{color:var(--ink-2)}
.right{text-align:right}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.divide{height:1px;background:var(--rule);margin:22px 0}
.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}
.stack-sm>*+*{margin-top:8px}

/* ---- accessibility + responsive --------------------------------------- */
:focus-visible{outline:2px solid var(--seal);outline-offset:2px;border-radius:4px}
.rail a:focus-visible{outline-color:#EAF1ED}

@media (max-width:1000px){
  .pipes,.grid-2,.grid-3{grid-template-columns:1fr}
  .kanban{grid-auto-flow:column;grid-auto-columns:78%;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
  .col{scroll-snap-align:start}
  .grid-in{grid-template-columns:1fr}
  .def{grid-template-columns:1fr;gap:4px}
}
@media (max-width:900px){
  .shell{grid-template-columns:1fr}
  .rail{position:fixed;left:0;top:0;height:100vh;width:236px;z-index:35;transform:translateX(-100%);transition:transform .2s ease}
  .rail.open{transform:none;box-shadow:0 0 40px rgba(19,37,30,.35)}
  .railtoggle{display:inline-flex}
  .top{padding:13px 18px}
  .wrap{padding:22px 18px 60px}
  .asof .st{display:none}
  .figs{gap:28px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
