:root{
  --ink:#14231C;
  --muted:#586A61;
  --faint:#8A978F;
  --brand:#0F6E56;
  --brand-strong:#0A4A3B;
  --brand-tint:#E4F3EC;
  --brand-line:#BFE0D2;
  --amber-tint:#FBEEDA;
  --amber-ink:#7A4B0A;
  --amber-line:#EED9B0;
  --surface:#FAF9F5;
  --card:#FFFFFF;
  --line:#E8E5DC;
  --line-strong:#D6D2C6;
  --radius:12px;
  --radius-lg:16px;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-head:"Spectral",Georgia,"Times New Roman",serif;
  --font-mono:"Spline Sans Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
  color-scheme:light;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--surface);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* top hairline accent — restrained signature */
.topbar{height:3px;background:var(--brand)}

.wrap{max-width:540px;margin:0 auto;padding:22px 20px 64px}
.wrap-wide{max-width:880px;margin:0 auto;padding:22px 20px 64px}

.site{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.wordmark{display:flex;align-items:center;gap:9px;font-family:var(--font-head);
  font-size:18px;font-weight:600;letter-spacing:.2px;color:var(--ink)}
.wordmark .mk{width:26px;height:26px;color:var(--brand)}
.site a.small,.small-link{font-size:13px;color:var(--muted)}

h1{font-family:var(--font-head);font-weight:600;font-size:26px;line-height:1.2;margin:0 0 6px}
h2{font-family:var(--font-head);font-weight:600;font-size:19px;margin:0 0 4px}
.lede{color:var(--muted);font-size:15px;margin:0 0 22px}

.muted{color:var(--muted)}
.faint{color:var(--faint)}
.eyebrow{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);
  font-weight:500;margin:0 0 10px}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:22px 22px}
.card + .card{margin-top:16px}
.section-gap{margin-top:26px}

/* icons */
.ic{width:1.2em;height:1.2em;stroke:currentColor;fill:none;stroke-width:1.7;
  stroke-linecap:round;stroke-linejoin:round;vertical-align:-.2em;flex:none}
.ic-lg{width:1.5em;height:1.5em}

/* identity block */
.who{display:flex;align-items:center;gap:14px}
.avatar{width:52px;height:52px;border-radius:50%;background:var(--brand-tint);
  color:var(--brand-strong);display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:18px;flex:none}
.avatar-lg{width:76px;height:76px;font-size:26px}
.who .name{font-weight:600;font-size:17px;margin:0}
.who .role{color:var(--muted);font-size:13px;margin:2px 0 0}

/* badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:500;
  padding:4px 11px;border-radius:999px;white-space:nowrap}
.b-ok{background:var(--brand-tint);color:var(--brand-strong)}
.b-progress{background:var(--amber-tint);color:var(--amber-ink)}
.b-muted{background:#F0EFEA;color:var(--muted)}
.b-live{background:var(--brand-tint);color:var(--brand-strong)}
.livedot{width:7px;height:7px;border-radius:50%;background:var(--brand);display:inline-block}

/* metric row */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 0 4px}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 14px}
.metric .k{font-size:12px;color:var(--muted);margin:0 0 5px}
.metric .v{font-size:19px;font-weight:600;margin:0}
.metric .v.big{font-size:24px}
.mono{font-family:var(--font-mono);letter-spacing:.5px}

/* credential list */
.creds{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  background:var(--card)}
.cred{display:flex;align-items:center;gap:13px;padding:14px 16px}
.cred + .cred{border-top:1px solid var(--line)}
.cred .cic{color:var(--muted);font-size:20px;display:flex}
.cred .body{flex:1;min-width:0}
.cred .t{font-size:15px;margin:0}
.cred .d{font-size:12.5px;color:var(--muted);margin:2px 0 0}

/* private / withheld rows */
.privacy{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:4px 16px}
.prow{display:flex;align-items:center;gap:12px;padding:12px 0}
.prow + .prow{border-top:1px solid var(--line)}
.prow .pic{color:var(--faint);font-size:18px;display:flex}
.prow .pt{flex:1;font-size:14px;color:var(--muted)}
.prow .ps{font-size:12.5px;color:var(--faint)}
.prow .ps.req{color:var(--brand)}

/* note strip */
.note{display:flex;gap:10px;align-items:flex-start;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:13px 15px}
.note .nic{color:var(--muted);font-size:18px;margin-top:1px;display:flex}
.note p{margin:0;font-size:13px;color:var(--muted);line-height:1.55}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-size:15px;font-weight:500;line-height:1;
  padding:12px 16px;border-radius:var(--radius);border:1px solid var(--line-strong);
  background:var(--card);color:var(--ink);cursor:pointer;text-decoration:none;
  transition:background .12s ease,border-color .12s ease}
.btn:hover{background:var(--surface);text-decoration:none}
.btn:active{transform:translateY(.5px)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-strong)}
.btn-danger{border-color:#E4C7C2;color:#8A3B2E;background:#fff}
.btn-danger:hover{background:#FBEEEB}
.btn-sm{padding:7px 11px;font-size:13px;gap:6px}
.btn-row{display:flex;gap:10px}
.btn-row .btn{flex:1}
.btn-block{width:100%}

/* forms */
label.f{display:block;font-size:13px;font-weight:500;color:var(--ink);margin:0 0 6px}
.hint{font-size:12px;color:var(--faint);margin:5px 0 0}
input[type=text],input[type=password],select,textarea{
  width:100%;font-family:var(--font-body);font-size:15px;color:var(--ink);
  background:var(--card);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:11px 13px;outline:none;transition:border-color .12s ease,box-shadow .12s ease}
input:focus,select:focus,textarea:focus{border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-tint)}
.field{margin:0 0 14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.checkline{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--ink);margin:2px 0 14px}
.checkline input{width:auto}

/* passport card */
.passport{border:1px solid var(--line);border-radius:20px;overflow:hidden;
  background:var(--card);max-width:360px;margin:0 auto}
.passport .head{background:var(--brand-tint);padding:15px 20px;display:flex;
  align-items:center;justify-content:space-between}
.passport .head .lab{display:flex;align-items:center;gap:8px;color:var(--brand-strong);
  font-family:var(--font-head);font-weight:600;font-size:15px}
.passport .idblk{padding:22px 20px 18px;text-align:center;border-bottom:1px solid var(--line)}
.passport .idblk .name{font-size:19px;font-weight:600;margin:12px 0 2px}
.passport .idblk .role{font-size:13px;color:var(--muted);margin:0 0 13px}
.passport .rows{padding:14px 20px;border-bottom:1px solid var(--line)}
.passport .r{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 0}
.passport .r .l{display:flex;align-items:center;gap:9px;font-size:14px}
.passport .r .l .cic{color:var(--muted);font-size:18px;display:flex}
.passport .r .s{font-size:12px;color:var(--brand-strong);display:flex;align-items:center;gap:4px}
.passport .qrbox{padding:20px;text-align:center}
.passport .qr{width:172px;height:172px;margin:0 auto 12px;display:flex;align-items:center;
  justify-content:center;border:1px solid var(--line);border-radius:var(--radius);
  background:#fff;padding:10px}
.passport .qr canvas,.passport .qr img{width:100%!important;height:100%!important}
.passport .foot{padding:11px 20px;background:var(--surface);border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;gap:6px;font-size:11.5px;color:var(--faint)}
.vlink{font-family:var(--font-mono);font-size:12px;word-break:break-all;color:var(--muted)}

/* verification seal — the signature element */
.seal{width:46px;height:46px;color:var(--brand)}

/* verify hero */
.vhero{background:var(--brand-tint);border:1px solid var(--brand-line);
  border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:center;gap:14px}
.vhero .disc{width:46px;height:46px;border-radius:50%;background:#fff;display:flex;
  align-items:center;justify-content:center;color:var(--brand);flex:none}
.vhero .vt{flex:1}
.vhero .vt h1{font-size:19px;color:var(--brand-strong);margin:0}
.vhero .vt p{font-size:13px;color:var(--brand-strong);opacity:.85;margin:2px 0 0}

/* admin table */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 22px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}
.stat .k{font-size:12px;color:var(--muted);margin:0 0 6px}
.stat .v{font-size:26px;font-weight:600;font-family:var(--font-head);margin:0}
.rowitem{display:flex;align-items:center;gap:13px;padding:14px 4px}
.rowitem + .rowitem{border-top:1px solid var(--line)}
.rowitem .body{flex:1;min-width:0}
.rowitem .body .n{font-weight:500;margin:0}
.rowitem .body .sub{font-size:12.5px;color:var(--muted);margin:2px 0 0}
.rowitem .acts{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}

.copyrow{display:flex;gap:8px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:9px 11px;margin:0 0 10px}
.copyrow .cl{font-size:11px;color:var(--faint);margin:0 0 2px}
.copyrow .cv{font-family:var(--font-mono);font-size:12.5px;color:var(--ink);word-break:break-all}
.copyrow .grow{flex:1;min-width:0}

.flash{background:var(--brand-tint);border:1px solid var(--brand-line);color:var(--brand-strong);
  border-radius:var(--radius);padding:11px 14px;font-size:14px;margin:0 0 16px}

.divider{height:1px;background:var(--line);margin:22px 0}
.center{text-align:center}
.stack>*+*{margin-top:10px}

:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}

@media (max-width:420px){
  .metrics{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}

/* ============ real v1 additions ============ */

/* signed-in top nav */
.nav{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 20px;border-bottom:1px solid var(--line);background:var(--card)}
.nav .brand{display:flex;align-items:center;gap:9px;font-family:var(--font-head);
  font-weight:600;font-size:17px;color:var(--ink)}
.nav .brand .mk{width:24px;height:24px;color:var(--brand)}
.nav .right{display:flex;align-items:center;gap:14px;font-size:13px}
.nav .right .who{color:var(--muted);max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav a{color:var(--muted)}

/* auth screens */
.authwrap{max-width:420px;margin:0 auto;padding:30px 20px 60px}
.rolepick{display:grid;gap:12px;margin:6px 0 4px}
.roletile{display:flex;align-items:center;gap:13px;border:1px solid var(--line-strong);
  border-radius:var(--radius);padding:15px 16px;cursor:pointer;background:var(--card);
  text-align:left;width:100%;transition:border-color .12s ease,background .12s ease}
.roletile:hover{border-color:var(--brand);background:var(--surface)}
.roletile .ric{width:38px;height:38px;border-radius:10px;background:var(--brand-tint);
  color:var(--brand-strong);display:flex;align-items:center;justify-content:center;flex:none}
.roletile .rt{font-weight:600;font-size:15px;margin:0}
.roletile .rd{font-size:12.5px;color:var(--muted);margin:1px 0 0}
.bigicon{width:44px;height:44px;color:var(--brand);margin:0 auto 12px;display:block}

/* subcard: one credential block inside a card */
.subcard{border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin:0 0 14px}
.subcard.head-ok{border-left:3px solid var(--brand)}
.subcard .sc-top{display:flex;align-items:center;gap:11px;margin:0 0 12px}
.subcard .sc-top .ci{color:var(--muted);display:flex}
.subcard .sc-top .ttl{font-weight:600;font-size:15px;margin:0;flex:1}
.subcard .sc-body{display:none;margin-top:12px}
.subcard.open .sc-body{display:block}
.subcard .editlink{font-size:13px;color:var(--brand);background:none;border:0;cursor:pointer;padding:0}

/* sharing toggle */
.toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer}
.toggle input{width:auto;margin:0}

/* compliance callout */
.callout{display:flex;gap:11px;align-items:flex-start;border-radius:var(--radius);padding:13px 15px;margin:14px 0}
.callout .cic{margin-top:1px;display:flex;flex:none}
.callout p{margin:0;font-size:13px;line-height:1.55}
.callout.amber{background:var(--amber-tint);border:1px solid var(--amber-line);color:var(--amber-ink)}
.callout.amber .cic{color:var(--amber-ink)}
.callout.info{background:var(--surface);border:1px solid var(--line);color:var(--muted)}

/* key/value detail rows (employer full check) */
.kv{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:12px 0}
.kv .row{display:flex;justify-content:space-between;gap:12px;padding:11px 14px;font-size:14px}
.kv .row + .row{border-top:1px solid var(--line)}
.kv .row .k{color:var(--muted)}
.kv .row .v{font-weight:500;text-align:right}
.kv .row .v.mono{font-family:var(--font-mono);font-weight:400}

/* search */
.searchbar{display:flex;gap:10px;margin:4px 0 2px}
.searchbar input{flex:1;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-mono)}
.searchbar input::placeholder{font-family:var(--font-body);letter-spacing:0;text-transform:none}

/* pending request row */
.reqrow{display:flex;align-items:center;gap:12px;padding:13px 4px}
.reqrow + .reqrow{border-top:1px solid var(--line)}
.reqrow .body{flex:1}
.reqrow .body .n{font-weight:500;margin:0;font-size:14px}
.reqrow .body .s{font-size:12.5px;color:var(--muted);margin:2px 0 0}
.reqrow .acts{display:flex;gap:8px}

.linkline{font-size:13px;color:var(--muted)}
.status-pill{font-size:12px;padding:3px 10px;border-radius:999px;background:#F0EFEA;color:var(--muted)}
.status-pill.released{background:var(--brand-tint);color:var(--brand-strong)}
.status-pill.requested{background:var(--amber-tint);color:var(--amber-ink)}

/* demo mode */
.demobar{background:var(--brand-tint);color:var(--brand-strong);text-align:center;
  font-size:13px;padding:9px 16px;border-bottom:1px solid var(--line)}
.demobar a{color:var(--brand-strong);text-decoration:underline;font-weight:600}
.demo-peek{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.demo-peek .eyebrow{margin-bottom:11px}
