:root{
  --bg:#f5f3ee;
  --bg2:#ece8de;
  --paper:#ffffff;
  --paper2:#fafaf6;
  --ink:#1a1d22;
  --ink-soft:#3d4248;
  --ink-dim:#6a7480;
  --ink-faint:#9aa3ae;
  --rule:#e1ddd0;
  --rule2:#d2cdbc;
  --green:#1a7f37;
  --green-soft:#d3f3df;
  --green-strong:#0d6928;
  --red:#cf222e;
  --red-soft:#ffe5e5;
  --amber:#bf8700;
  --amber-soft:#fff3cd;
  --merged:#8250df;
  --merged-soft:#ebe1ff;
  --code-bg:#0d1117;
  --code-bg2:#161b22;
  --code-ink:#e6edf3;
  --code-ink-dim:#7d8590;
  --code-green:#3fb950;
  --code-red:#f85149;
  --code-violet:#a371f7;
  --maxw:1180px;
  --content-w:760px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:'JetBrains Mono','IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;line-height:1.55;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{min-height:100vh;background:
  radial-gradient(ellipse at 90% 0%, rgba(26,127,55,0.05) 0%, transparent 55%),
  radial-gradient(ellipse at 0% 100%, rgba(130,80,223,0.04) 0%, transparent 60%),
  var(--bg);
  background-attachment:fixed;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* === TOP STRIP (GitHub-ish "repo header") === */
.repostrip{background:var(--paper);border-bottom:1px solid var(--rule);padding:10px 0;font-size:12.5px}
.repostrip .in{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.repostrip .crumbs{display:flex;align-items:center;gap:7px;color:var(--ink-dim);min-width:0;overflow:hidden}
.repostrip .crumbs .mk{width:18px;height:18px;color:var(--green);flex-shrink:0}
.repostrip .crumbs .org{color:var(--ink-soft);font-weight:500}
.repostrip .crumbs .slash{color:var(--rule2)}
.repostrip .crumbs .repo{color:var(--ink);font-weight:700}
.repostrip .crumbs .pub{margin-left:8px;font-size:10px;padding:1px 8px;border:1px solid var(--rule2);border-radius:14px;color:var(--ink-dim);letter-spacing:0.5px;text-transform:uppercase}
.repostrip .actions{display:flex;gap:6px;flex-wrap:wrap}
.repostrip .actions a{padding:5px 10px;font-size:11px;color:var(--ink-soft);border:1px solid var(--rule);background:var(--paper2);font-weight:600;letter-spacing:0.5px;transition:background .12s;display:inline-flex;align-items:center;gap:5px}
.repostrip .actions a:hover{background:var(--bg2)}
.repostrip .actions a .n{color:var(--ink-dim);background:var(--bg);padding:1px 6px;border:1px solid var(--rule);font-size:10px}

/* === PR TITLE BAR === */
.prhead{background:var(--paper);border-bottom:1px solid var(--rule);padding:22px 0 18px}
.prhead .in{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.prhead h1{font-size:clamp(22px,4vw,32px);font-weight:700;color:var(--ink);line-height:1.25;letter-spacing:-0.5px;font-family:inherit}
.prhead h1 .num{color:var(--ink-faint);font-weight:500;margin-left:6px}
.prhead .submeta{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-top:12px;font-size:12.5px;color:var(--ink-dim)}
.prhead .submeta .status{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:18px;font-size:11.5px;font-weight:700;letter-spacing:0.5px}
.prhead .submeta .status.open{background:var(--green-soft);color:var(--green-strong);border:1px solid var(--green)}
.prhead .submeta .status.merged{background:var(--merged-soft);color:var(--merged);border:1px solid var(--merged)}
.prhead .submeta .status .dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.prhead .submeta .pill{padding:2px 8px;background:var(--bg2);border:1px solid var(--rule);font-size:11px;color:var(--ink-soft);font-weight:500}
.prhead .submeta .pill code{font-family:inherit;color:var(--ink)}

/* === TABS NAV (sticky, horizontal-scroll on mobile) === */
.tabs{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid var(--rule);overflow-x:auto;-webkit-overflow-scrolling:touch}
.tabs .in{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;align-items:stretch;gap:0;min-width:max-content}
.tabs a{padding:14px 16px;font-size:12.5px;color:var(--ink-dim);font-weight:600;letter-spacing:0.5px;border-bottom:2px solid transparent;transition:all .12s;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.tabs a:hover{color:var(--ink);background:var(--paper2)}
.tabs a.active{color:var(--ink);border-bottom-color:var(--green);font-weight:700}
.tabs a .ico{width:14px;height:14px;color:var(--ink-faint)}
.tabs a.active .ico{color:var(--green)}
.tabs a .n{background:var(--bg2);color:var(--ink-soft);padding:1px 7px;font-size:10.5px;border-radius:10px;font-weight:600}
.tabs a.active .n{background:var(--green);color:var(--paper)}

/* === MAIN LAYOUT (content + sidebar) === */
.pr{max-width:var(--maxw);margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}
@media (max-width:880px){
  .pr{grid-template-columns:1fr;gap:18px;padding:18px}
}

/* === CONTENT (comment thread style) === */
.thread{min-width:0}

/* avatar + comment combo */
.comment{display:grid;grid-template-columns:42px 1fr;gap:14px;margin-bottom:18px;align-items:start}
.comment .av{width:42px;height:42px;background:var(--paper);border:1px solid var(--rule2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.5px;overflow:hidden;flex-shrink:0}
.comment .av.system{background:var(--green-soft);color:var(--green-strong);border-color:var(--green)}
.comment .av svg{width:22px;height:22px}
.comment .bub{background:var(--paper);border:1px solid var(--rule);min-width:0}
.comment .bub .h{padding:8px 14px;background:var(--paper2);border-bottom:1px solid var(--rule);border-top-left-radius:0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px}
.comment .bub .h .who{color:var(--ink-soft);font-weight:600}
.comment .bub .h .who b{color:var(--ink)}
.comment .bub .h .meta{color:var(--ink-dim);font-size:11.5px}
.comment .bub .b{padding:18px 20px;color:var(--ink-soft);font-size:14px;line-height:1.72}
.comment .bub .b b,.comment .bub .b strong{color:var(--ink)}
.comment .bub .b p+p{margin-top:12px}
.comment .bub .b h2{font-size:17px;color:var(--ink);font-weight:700;margin:6px 0 10px;letter-spacing:-0.3px}
.comment .bub .b h2 .green{color:var(--green-strong)}
.comment .bub .b h3{font-size:14.5px;color:var(--ink);font-weight:700;margin:18px 0 8px;letter-spacing:-0.2px}
.comment .bub .b ul{margin:8px 0 12px 22px;color:var(--ink-soft)}
.comment .bub .b ul li{margin-bottom:5px;line-height:1.7}
.comment .bub .b ul li::marker{color:var(--green)}
.comment .bub .b code{font-family:inherit;background:var(--bg2);padding:2px 6px;border:1px solid var(--rule);color:var(--ink);font-size:13px}
.comment .bub .b a.link{color:var(--green-strong);text-decoration:underline;text-decoration-color:var(--green)}
.comment .bub .b a.link:hover{color:var(--green)}
.comment .bub .b blockquote{padding:10px 14px;background:var(--paper2);border-left:3px solid var(--green);color:var(--ink-soft);margin:12px 0;font-size:13.5px;font-style:italic}

@media (max-width:760px){
  .comment{grid-template-columns:32px 1fr;gap:10px;margin-bottom:14px}
  .comment .av{width:32px;height:32px;font-size:10px}
  .comment .av svg{width:18px;height:18px}
  .comment .bub .b{padding:14px 16px;font-size:13.5px}
  .comment .bub .h{padding:7px 12px;font-size:11.5px}
}

/* === HUGE HERO COMMENT (the PR description) === */
.hero-comment .bub{border-color:var(--green);box-shadow:0 0 0 1px var(--green-soft)}
.hero-comment .bub .h{background:var(--green-soft);color:var(--green-strong);border-bottom-color:var(--green)}
.hero-comment .bub .b h1{font-size:clamp(28px,5vw,46px);line-height:1.05;font-weight:700;color:var(--ink);letter-spacing:-1.2px;margin:4px 0 14px;font-family:inherit}
.hero-comment .bub .b h1 .green{color:var(--green-strong)}
.hero-comment .bub .b h1 .merged{color:var(--merged)}
.hero-comment .bub .b .tagline{color:var(--ink-soft);font-size:15px;line-height:1.7;max-width:560px}
.hero-comment .bub .b .ctarow{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.hero-comment .bub .b .ctarow .btn{padding:10px 16px;border:1px solid var(--ink);font-family:inherit;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:var(--paper);color:var(--ink);cursor:pointer;transition:all .12s}
.hero-comment .bub .b .ctarow .btn:hover{background:var(--ink);color:var(--paper)}
.hero-comment .bub .b .ctarow .btn.primary{background:var(--green);color:var(--paper);border-color:var(--green)}
.hero-comment .bub .b .ctarow .btn.primary:hover{background:var(--green-strong);border-color:var(--green-strong)}
.hero-comment .bub .b .ctarow .btn.merged{background:var(--merged);color:var(--paper);border-color:var(--merged)}
.hero-comment .bub .b .ctarow .btn.merged:hover{filter:brightness(0.92)}

/* === DIFF BLOCK (inset code, dark) === */
.diff{background:var(--code-bg);border:1px solid var(--rule);margin:14px 0;overflow:hidden;color:var(--code-ink);font-size:12.5px;line-height:1.7}
.diff .head{padding:8px 14px;background:var(--code-bg2);border-bottom:1px solid #21262d;color:var(--code-ink-dim);font-size:11.5px;letter-spacing:0.5px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.diff .head .f{color:var(--code-ink);font-weight:600;font-family:inherit}
.diff .head .stat{display:flex;gap:8px;font-weight:600;font-size:11px}
.diff .head .stat .add{color:var(--code-green)}
.diff .head .stat .del{color:var(--code-red)}
.diff .body{padding:8px 0;overflow-x:auto}
.diff .ln{display:flex;align-items:flex-start;padding:0 16px;min-width:max-content}
.diff .ln .n{color:var(--code-ink-dim);font-size:11px;min-width:32px;text-align:right;flex-shrink:0;padding-right:14px;opacity:0.7}
.diff .ln .c{font-family:inherit;font-size:12.5px;white-space:pre;color:var(--code-ink)}
.diff .ln.add{background:rgba(63,185,80,0.13)}
.diff .ln.add .c::before{content:"+ ";color:var(--code-green);font-weight:600}
.diff .ln.del{background:rgba(248,81,73,0.13)}
.diff .ln.del .c::before{content:"- ";color:var(--code-red);font-weight:600}
.diff .ln.ctx .c::before{content:"  ";color:var(--code-ink-dim)}
.diff .ln.note{background:#1c2128}
.diff .ln.note .c{color:var(--code-violet);font-style:italic}
.diff .ln.note .c::before{content:"@@ ";color:var(--code-violet)}

@media (max-width:760px){
  .diff .ln{padding:0 10px}
  .diff .ln .n{min-width:24px;padding-right:10px}
}

/* === CI CHECKS BLOCK (inside a comment) === */
.ci{background:var(--paper2);border:1px solid var(--rule);margin:14px 0}
.ci .row{display:grid;grid-template-columns:24px 1fr auto;gap:10px;padding:10px 14px;border-bottom:1px solid var(--rule);align-items:center;font-size:12.5px}
.ci .row:last-child{border-bottom:none}
.ci .row .ic{width:16px;height:16px}
.ci .row.ok .ic{color:var(--green)}
.ci .row.fail .ic{color:var(--red)}
.ci .row.pend .ic{color:var(--amber)}
.ci .row .nm{color:var(--ink-soft);font-weight:600}
.ci .row .nm .sm{color:var(--ink-dim);font-weight:400;font-size:11.5px;margin-left:6px}
.ci .row .t{color:var(--ink-dim);font-size:11.5px}

/* === FEATURE GRID (replaces card grid, uses dl-style spec) === */
.spec{background:var(--paper);border:1px solid var(--rule);margin-top:14px}
.spec .item{display:grid;grid-template-columns:160px 1fr;gap:14px;padding:14px 18px;border-bottom:1px solid var(--rule);align-items:start}
.spec .item:last-child{border-bottom:none}
.spec .item .k{color:var(--ink-soft);font-size:11.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding-top:2px}
.spec .item .v{color:var(--ink);font-size:13.5px;line-height:1.65}
.spec .item .v b{color:var(--green-strong)}
@media (max-width:760px){
  .spec .item{grid-template-columns:1fr;gap:4px;padding:12px 14px}
  .spec .item .k{font-size:10.5px}
}

/* === STATS STRIP === */
.statstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);margin:14px 0}
.statstrip .s{background:var(--paper);padding:14px 16px;text-align:left}
.statstrip .s .v{font-size:22px;color:var(--ink);font-weight:700;letter-spacing:-0.5px;line-height:1}
.statstrip .s .v.green{color:var(--green-strong)}
.statstrip .s .v.merged{color:var(--merged)}
.statstrip .s .l{font-size:10px;color:var(--ink-dim);letter-spacing:1.5px;text-transform:uppercase;margin-top:6px;font-weight:600}
@media (max-width:760px){
  .statstrip{grid-template-columns:1fr 1fr;gap:1px}
  .statstrip .s .v{font-size:18px}
}

/* === MERGE PANEL (big green button thing at the bottom) === */
.mergepanel{background:var(--paper);border:1px solid var(--rule);padding:0;margin-top:32px}
.mergepanel .h{padding:14px 18px;background:var(--green-soft);border-bottom:1px solid var(--green);color:var(--green-strong);font-size:13px;font-weight:700;letter-spacing:0.5px;display:flex;align-items:center;gap:10px}
.mergepanel .h svg{width:18px;height:18px}
.mergepanel .b{padding:18px;display:flex;flex-direction:column;gap:14px}
.mergepanel .b .desc{color:var(--ink-soft);font-size:13px;line-height:1.7}
.mergepanel .b .btn{background:var(--green);color:var(--paper);border:1px solid var(--green-strong);padding:14px 22px;font-family:inherit;font-size:13.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .12s;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:10px}
.mergepanel .b .btn:hover{background:var(--green-strong)}
.mergepanel .b .btn svg{width:18px;height:18px}

/* === SIDEBAR === */
.side{display:flex;flex-direction:column;gap:18px}
@media (max-width:880px){.side{order:2}}
.sidemod{background:var(--paper);border:1px solid var(--rule)}
.sidemod .h{padding:10px 14px;border-bottom:1px solid var(--rule);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft);font-weight:700;display:flex;justify-content:space-between;align-items:center;background:var(--paper2)}
.sidemod .h a{color:var(--green-strong);font-size:10.5px;letter-spacing:1px}
.sidemod .b{padding:14px;font-size:13px;color:var(--ink-soft)}
.sidemod .b .lt{padding:6px 0;color:var(--ink-dim);font-size:12px;line-height:1.6;border-bottom:1px dashed var(--rule)}
.sidemod .b .lt:last-child{border-bottom:none}
.sidemod .b .lt b{color:var(--ink)}
.sidemod .b .reviewer{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:12px;border-bottom:1px dashed var(--rule)}
.sidemod .b .reviewer:last-child{border-bottom:none}
.sidemod .b .reviewer .av{width:24px;height:24px;border-radius:50%;background:var(--bg2);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--ink-soft);flex-shrink:0;overflow:hidden}
.sidemod .b .reviewer .nm{flex:1;color:var(--ink);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidemod .b .reviewer .stat{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--green-strong);font-weight:700}
.sidemod .b .reviewer .stat.dim{color:var(--ink-dim)}
.sidemod .b .biglink{display:block;padding:12px;background:var(--green);color:var(--paper);text-align:center;font-size:11px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;margin-top:8px;transition:background .12s}
.sidemod .b .biglink:hover{background:var(--green-strong)}

/* === BOARD PAGE === */
.boardwrap{max-width:var(--maxw);margin:0 auto;padding:24px}
.boardfilters{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px;font-size:12px}
.boardfilters input{background:var(--paper);border:1px solid var(--rule);color:var(--ink);padding:7px 11px;font-family:inherit;font-size:12.5px;min-width:200px}
.boardfilters input::placeholder{color:var(--ink-faint)}
.boardfilters input:focus{outline:none;border-color:var(--green)}
.boardfilters .seg{display:inline-flex;border:1px solid var(--rule);background:var(--paper)}
.boardfilters .seg button{background:transparent;border:none;color:var(--ink-dim);font-family:inherit;font-size:11px;padding:7px 11px;cursor:pointer;letter-spacing:0.5px;text-transform:uppercase;font-weight:600}
.boardfilters .seg button.on{background:var(--green);color:var(--paper)}
.boardfilters .live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--green-strong);font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
.boardfilters .live::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{50%{opacity:0.3}}

.prrow{display:grid;grid-template-columns:32px 1fr auto auto auto auto;gap:14px;padding:14px 16px;background:var(--paper);border:1px solid var(--rule);margin-bottom:6px;align-items:center;font-size:13px;transition:all .12s}
.prrow:hover{border-color:var(--green);background:var(--paper2)}
.prrow .badge{width:26px;height:26px;border-radius:50%;background:var(--green-soft);border:1px solid var(--green);display:inline-flex;align-items:center;justify-content:center;color:var(--green-strong)}
.prrow .badge svg{width:14px;height:14px}
.prrow .badge.merged{background:var(--merged-soft);border-color:var(--merged);color:var(--merged)}
.prrow .badge.draft{background:var(--bg2);border-color:var(--rule2);color:var(--ink-dim)}
.prrow .repo{min-width:0}
.prrow .repo .top{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.prrow .repo .name{color:var(--ink);font-weight:700;font-size:13.5px}
.prrow .repo .num{color:var(--ink-dim);font-size:12px}
.prrow .repo .title{color:var(--ink-soft);font-size:13px;margin-top:3px;line-height:1.5}
.prrow .repo .meta{display:flex;gap:10px;margin-top:5px;font-size:10.5px;color:var(--ink-dim);letter-spacing:0.5px}
.prrow .repo .meta .diff .a{color:var(--green-strong);font-weight:700}
.prrow .repo .meta .diff .d{color:var(--red);font-weight:700}
.prrow .age{font-size:11px;color:var(--ink-dim);white-space:nowrap}
.prrow .pool{text-align:right;white-space:nowrap}
.prrow .pool .v{font-size:14px;color:var(--green-strong);font-weight:700;line-height:1}
.prrow .pool .l{font-size:9.5px;color:var(--ink-dim);letter-spacing:1px;text-transform:uppercase;margin-top:3px;font-weight:600}
.prrow .vouchcount{text-align:right;white-space:nowrap}
.prrow .vouchcount .v{font-size:14px;color:var(--ink);font-weight:700;line-height:1}
.prrow .vouchcount .l{font-size:9.5px;color:var(--ink-dim);letter-spacing:1px;text-transform:uppercase;margin-top:3px;font-weight:600}
.prrow .vouch{background:var(--green);color:var(--paper);border:1px solid var(--green-strong);padding:8px 13px;font-family:inherit;font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;cursor:pointer;white-space:nowrap}
.prrow .vouch:hover{background:var(--green-strong)}
@media (max-width:760px){
  .prrow{grid-template-columns:32px 1fr auto;gap:10px;padding:12px 12px}
  .prrow .age,.prrow .pool,.prrow .vouchcount{display:none}
}

/* === FORM (accelerate page) === */
.formcard{background:var(--paper);border:1px solid var(--rule);padding:0}
.formcard .fh{padding:14px 18px;background:var(--paper2);border-bottom:1px solid var(--rule);font-size:13px;font-weight:700;color:var(--ink-soft);letter-spacing:0.5px}
.formcard .fb{padding:20px}
.formcard .field{margin-bottom:16px}
.formcard .field label{display:block;font-size:11px;color:var(--ink-soft);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.formcard .field input,.formcard .field select,.formcard .field textarea{width:100%;background:var(--bg);border:1px solid var(--rule2);color:var(--ink);padding:10px 12px;font-family:inherit;font-size:13.5px}
.formcard .field input:focus,.formcard .field select:focus,.formcard .field textarea:focus{outline:none;border-color:var(--green);background:var(--paper)}
.formcard .hint{font-size:11px;color:var(--ink-dim);margin-top:5px;line-height:1.5}
.formcard .twoinp{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:560px){.formcard .twoinp{grid-template-columns:1fr}}
.formcard .walletbox{padding:12px;background:var(--bg);border:1px dashed var(--rule2);font-size:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.formcard .walletbox.conn{border-color:var(--green);border-style:solid;background:var(--green-soft)}
.formcard .walletbox .addr{color:var(--green-strong);font-size:11.5px;font-weight:600}
.formcard .walletbox button{background:var(--ink);color:var(--paper);border:1px solid var(--ink);padding:7px 14px;font-family:inherit;font-size:11px;letter-spacing:1px;font-weight:700;cursor:pointer;text-transform:uppercase}
.formcard .walletbox button:hover{background:var(--green);border-color:var(--green)}
.formcard .summary{background:var(--bg);border:1px solid var(--rule2);padding:14px 16px;font-size:12.5px;line-height:1.85}
.formcard .summary .r{display:flex;justify-content:space-between;color:var(--ink)}
.formcard .summary .r .k{color:var(--ink-dim)}
.formcard .summary .r.tot{border-top:1px dashed var(--rule2);margin-top:8px;padding-top:8px;font-weight:700;color:var(--green-strong)}
.formcard .submit{width:100%;background:var(--green);color:var(--paper);border:1px solid var(--green-strong);padding:14px;font-family:inherit;font-size:12.5px;letter-spacing:2px;font-weight:700;cursor:pointer;text-transform:uppercase;transition:background .12s}
.formcard .submit:disabled{background:var(--rule2);color:var(--ink-faint);border-color:var(--rule);cursor:not-allowed}
.formcard .submit:not(:disabled):hover{background:var(--green-strong)}

/* === MODAL (used on board for vouch confirmation) === */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:18px;z-index:120}
.modal-bg.show{display:flex}
.modal-card{background:var(--paper);border:1px solid var(--green);max-width:520px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,0.18)}
.modal-card .mh{padding:14px 18px;border-bottom:1px solid var(--rule);background:var(--green-soft);display:flex;justify-content:space-between;align-items:center}
.modal-card .mh h3{font-size:13px;color:var(--green-strong);font-weight:700;letter-spacing:1px;text-transform:uppercase}
.modal-card .mclose{background:none;border:none;color:var(--ink-soft);cursor:pointer;font-family:inherit;font-size:20px;padding:0;line-height:1}
.modal-card .mclose:hover{color:var(--ink)}
.modal-card .mb{padding:18px}
.modal-card .mdetail{background:var(--bg);border:1px solid var(--rule);padding:12px 14px;font-size:12.5px;line-height:1.85;margin-bottom:16px}
.modal-card .mdetail .r{display:flex;justify-content:space-between;color:var(--ink)}
.modal-card .mdetail .r .k{color:var(--ink-dim)}
.modal-card .mdetail .r .v{color:var(--ink);font-weight:600}
.modal-card .mdetail .r .v.green{color:var(--green-strong)}
.modal-card .mdetail .r .v.red{color:var(--red)}
.modal-card .field{margin-bottom:14px}
.modal-card .field label{display:block;font-size:10.5px;color:var(--ink-soft);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.modal-card .field input{width:100%;background:var(--bg);border:1px solid var(--rule2);color:var(--ink);padding:9px 11px;font-family:inherit;font-size:12.5px}
.modal-card .field input:focus{outline:none;border-color:var(--green)}
.modal-card .field .hint{font-size:11px;color:var(--ink-dim);margin-top:5px;line-height:1.5}
.modal-card .mfoot{padding:12px 18px;border-top:1px solid var(--rule);background:var(--paper2);display:flex;gap:8px;justify-content:flex-end}
.modal-card .mfoot button{font-family:inherit;font-size:11px;padding:9px 16px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;cursor:pointer;border:1px solid}
.modal-card .mfoot .cancel{background:transparent;border-color:var(--rule2);color:var(--ink-soft)}
.modal-card .mfoot .cancel:hover{background:var(--bg2);color:var(--ink)}
.modal-card .mfoot .confirm{background:var(--green);border-color:var(--green-strong);color:var(--paper)}
.modal-card .mfoot .confirm:hover{background:var(--green-strong)}

/* === TOAST === */
.toast{position:fixed;bottom:24px;right:24px;background:var(--paper);border:1px solid var(--green);padding:14px 18px;font-size:12.5px;color:var(--ink-soft);max-width:340px;box-shadow:0 6px 16px rgba(0,0,0,0.15);display:none;z-index:100}
.toast.show{display:block}
.toast .title{color:var(--green-strong);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;margin-bottom:6px}

/* === FOOTER (styled as a git commit trailer) === */
footer{margin-top:40px;background:var(--code-bg);color:var(--code-ink-dim);font-size:12px;line-height:1.85;font-family:inherit;border-top:1px solid #21262d}
footer .ftin{max-width:var(--maxw);margin:0 auto;padding:22px 28px}
footer .ftcmt{font-size:11px;color:var(--code-ink-dim);letter-spacing:0.5px;margin-bottom:8px}
footer .ftcmt .sha{color:var(--code-green);font-weight:700;margin-right:8px}
footer .ftcmt .br{color:var(--code-violet);margin-right:8px}
footer .fttitle{color:var(--code-ink);font-size:13.5px;font-weight:700;margin-bottom:14px;letter-spacing:-0.2px}
footer .ftrail{font-size:12px;color:var(--code-ink-dim);line-height:1.85}
footer .ftrail .k{color:var(--code-violet);font-weight:600}
footer .ftrail .v{color:var(--code-ink)}
footer .ftrail a{color:var(--code-green);text-decoration:none;border-bottom:1px dashed transparent}
footer .ftrail a:hover{border-bottom-color:var(--code-green)}
footer .ftbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:18px;padding-top:14px;border-top:1px dashed #21262d;font-size:10.5px;color:var(--code-ink-dim);letter-spacing:1px;text-transform:uppercase;flex-wrap:wrap}
footer .ftbar .ll{display:flex;align-items:center;gap:10px}
footer .ftbar .ll svg{width:14px;height:14px;color:var(--code-green)}
footer .ftbar .lr{display:flex;gap:14px;flex-wrap:wrap}
footer .ftbar .lr a{color:var(--code-ink-dim);font-weight:600;letter-spacing:1px}
footer .ftbar .lr a:hover{color:var(--code-green)}
@media (max-width:760px){
  footer .ftin{padding:18px 18px}
  footer .ftrail{font-size:11.5px}
  footer .ftbar{font-size:10px}
}

:target{scroll-margin-top:64px}
