/* ============================================================
   PESKEL — feed & components
   ============================================================ */

/* app surface inside a frame */
.app{position:relative;height:100%;background:var(--bg);color:var(--ink);
  font-family:var(--font-ui);display:flex;flex-direction:column}

/* ---- demo ribbon (tiny, required disclaimer) ---- */
.ribbon{
  flex:0 0 auto;text-align:center;padding:6px 12px;
  font-family:var(--font-mono);font-size:9.5px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-3);
  background:var(--surface-sunken);border-bottom:1px solid var(--hair);
}
.ribbon b{color:var(--ink-2)}

/* ---- top bar ---- */
.topbar{
  flex:0 0 auto;display:flex;align-items:center;gap:12px;
  padding:14px 18px;background:var(--glass);backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border-bottom:1px solid var(--hair);position:relative;z-index:30;
}
.web .topbar{padding:15px 26px}
.brand{display:flex;align-items:center;gap:10px}
.brand .word{font-size:21px;font-weight:800;letter-spacing:-.045em;color:var(--ink)}
.web .brand .word{font-size:23px}
.topbar .spacer{flex:1}
.web-nav{display:none;gap:6px}
.web .web-nav{display:flex}
.web-nav a{
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.06em;white-space:nowrap;
  text-transform:uppercase;color:var(--ink-2);text-decoration:none;
  padding:8px 13px;border-radius:9px;transition:background .15s,color .15s;
}
.web-nav a:hover{background:var(--surface-sunken);color:var(--ink)}
.web-nav a.on{color:var(--ink);background:var(--surface-sunken)}

.loc{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  border:1px solid var(--hair-2);border-radius:999px;padding:7px 12px 7px 11px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--ink);white-space:nowrap;
  background:transparent;transition:border-color .15s,background .15s;
}
.loc:hover{background:var(--surface-sunken)}
.loc svg{width:13px;height:13px}
.icon-btn{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--hair-2);
  background:transparent;color:var(--ink);display:grid;place-items:center;cursor:pointer;
  transition:background .15s,border-color .15s;
}
.icon-btn:hover{background:var(--surface-sunken)}
.icon-btn svg{width:17px;height:17px}
.btn-solid{
  display:inline-flex;align-items:center;gap:7px;border:0;cursor:pointer;
  background:var(--solid-ink);color:var(--on-solid);border-radius:999px;
  padding:10px 17px;font-family:var(--font-ui);font-weight:700;font-size:13.5px;letter-spacing:-.01em;
  transition:transform .12s, filter .15s; box-shadow:var(--shadow-sm);
}
.btn-solid:hover{filter:brightness(.92)}
.btn-solid:active{transform:scale(.97)}
.btn-solid svg{width:15px;height:15px}

/* ---- edition dateline ---- */
.dateline{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 18px;border-bottom:1px solid var(--hair);
  font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.04em;
  color:var(--ink-3);background:var(--surface-2);
}
.web .dateline{padding:11px 26px}
.dateline b{color:var(--ink-2);font-weight:600}
.dateline>span{white-space:nowrap}
.dateline>span:first-child{overflow:hidden;text-overflow:ellipsis}
.dateline .live{display:inline-flex;align-items:center;gap:6px;color:var(--ink-2)}
.dateline .live .pulse{width:6px;height:6px;border-radius:50%;background:var(--p-green);
  box-shadow:0 0 0 0 var(--p-green);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(44,140,106,.5)}70%{box-shadow:0 0 0 7px rgba(44,140,106,0)}100%{box-shadow:0 0 0 0 rgba(44,140,106,0)}}

/* ---- segmented tabs ---- */
.tabs{display:flex;gap:4px;padding:12px 18px 4px}
.web .tabs{padding:14px 26px 6px}
.tab{
  font-family:var(--font-ui);font-size:13px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;
  color:var(--ink-2);background:transparent;border:0;cursor:pointer;
  padding:8px 14px;border-radius:999px;transition:background .15s,color .15s;
}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--on-solid);background:var(--solid-ink)}

/* ---- feed scroll body ---- */
.feed{padding:14px 16px 90px;display:flex;flex-direction:column;gap:18px}
.web .feed{
  padding:22px 26px 60px;display:grid;gap:22px;
  grid-template-columns:1fr 1fr;align-items:start;
}
.web .feed .span2{grid-column:1/-1}

/* =====================================================
   POLL CARD
   ===================================================== */
.card{
  background:var(--surface);border:1px solid var(--hair);border-radius:24px;
  box-shadow:none;overflow:hidden;position:relative;
  transition:border-color .25s;
}
.card:hover{border-color:var(--hair-2)}
.card-pad{padding:18px 18px 16px}
.web .card-pad{padding:22px 22px 18px}

/* meta row */
.meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:11px}
.chip{
  font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--hair-2);border-radius:7px;padding:4px 8px;line-height:1;
  display:inline-flex;align-items:center;gap:6px;
}
.chip.cat{color:var(--ink);border-color:var(--ink)}
.chip .sq{width:7px;height:7px;border-radius:2px}
.chip.live{color:var(--ink)}
.chip.live .sq{background:var(--p-green);border-radius:50%;animation:pulse 2s infinite}
.meta .when{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);margin-left:auto}

/* card top: author + time·status */
.ctop{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:2px}
.author{display:flex;align-items:center;gap:9px;min-width:0}
.author .ava{width:34px;height:34px;border-radius:50%;background:var(--surface-sunken);
  display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--ink-2);overflow:hidden;flex:0 0 auto;
  box-shadow:inset 0 0 0 1px var(--hair)}
.author .ava img{width:100%;height:100%;object-fit:cover}
.author .awho{display:flex;flex-direction:column;min-width:0;line-height:1.15}
.author .aname{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:700;color:var(--ink);
  letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.author .ahandle{font-size:11.5px;color:var(--ink-3);font-weight:500}
.author .vbadge{flex:0 0 auto;display:inline-grid;place-items:center;color:var(--ink)}
.author .vbadge svg{width:14px;height:14px;display:block}

.status{display:inline-flex;align-items:center;gap:7px;flex:0 0 auto;
  font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);white-space:nowrap;padding-top:2px}
.status .dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.status .dot.open{background:var(--p-blue);box-shadow:0 0 0 3px rgba(53,99,201,.16)}
.status .dot.closed{background:var(--ink-3);opacity:.5}

.q{font-size:21px;font-weight:700;letter-spacing:-.022em;line-height:1.16;color:var(--ink);
  margin:8px 0 2px;text-wrap:balance}
.web .q{font-size:23px}

/* ---- the two numbers / segmented data switch ---- */
.numseg{
  display:inline-flex;gap:2px;margin:14px 0 6px;padding:3px;border-radius:11px;
  background:var(--surface-sunken);border:1px solid var(--hair);
}
.numseg button{
  font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.07em;
  text-transform:uppercase;color:var(--ink-3);background:transparent;border:0;cursor:pointer;
  padding:6px 11px;border-radius:8px;transition:color .15s,background .15s;
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1;
}
.numseg button .lab{}
.numseg button.on{color:var(--ink);background:var(--surface);box-shadow:var(--shadow-sm)}

/* =====================================================
   HORIZONTAL BARS (single + electoral current standing)
   ===================================================== */
.bars{display:flex;flex-direction:column;gap:1px;margin-top:6px;position:relative}
.opt{
  display:flex;align-items:center;gap:11px;flex-wrap:wrap;
  padding:6px 8px;margin:0 -8px;position:relative;border-radius:12px;
  transition:background .18s;
}
.opt .ph{
  order:0;width:32px;height:32px;border-radius:50%;background:var(--surface-sunken);flex:0 0 auto;
  display:grid;place-items:center;color:#fff;overflow:hidden;position:relative;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);transition:box-shadow .18s,transform .18s;
}
.opt .ph .slot{position:absolute;inset:0;background-size:cover;background-position:center}
.opt .ph .slotlabel{position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.02em;
  text-align:center;color:rgba(255,255,255,.92)}
.opt .body{order:1;flex:1 1 auto;min-width:0}
.opt .nm{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}
.opt .desc{font-size:11.5px;line-height:1.3;color:var(--ink-3);margin-top:1px;font-weight:450;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.opt .pct{order:2;margin-left:auto;flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;line-height:1.02}
.opt .pct .pnum{font-family:var(--font-mono);font-weight:600;font-size:16px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.opt .pct small{font-size:10px;color:var(--ink-3);font-weight:500}
.opt .pct .vcount{font-family:var(--font-mono);font-size:9px;color:var(--ink-3);font-variant-numeric:tabular-nums;
  white-space:nowrap;opacity:0;max-height:0;overflow:hidden;transition:opacity .25s,max-height .25s,margin-top .25s}
.opt .pct .vcount.show{opacity:1;max-height:14px;margin-top:2px}
.opt .pct .vcount.tick{animation:tickup .42s ease}
@keyframes tickup{0%{transform:translateY(-4px);opacity:.3}100%{transform:translateY(0);opacity:1}}
/* track spanning full row, under content */
.opt .bar{order:3;flex:0 0 100%;width:100%;height:6px;border-radius:5px;background:var(--track);position:relative;overflow:hidden;margin-top:2px}
/* ANTI-VIÉS: hide results until the user votes */
.card.prevote .opt .pct{visibility:hidden}
.card.prevote .opt .bar .fill{width:0!important;opacity:0}
.card.prevote .opt .bar{background:var(--track);opacity:.55}
.card.prevote .opt{cursor:default}
.prevote-hint{display:none;align-items:center;gap:7px;margin-top:11px;padding:9px 12px;border-radius:11px;
  background:var(--surface-sunken);font-family:var(--font-mono);font-size:10.5px;color:var(--ink-2);letter-spacing:.02em}
.card.prevote .prevote-hint{display:flex}
.prevote-hint svg{width:13px;height:13px;flex:0 0 auto;color:var(--ink)}
/* ===== detail page: photo on top + normal poll panel below ===== */
.carddetail{display:flex;flex-direction:column;overflow:hidden}
.carddetail .detail-photo{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;
  background:linear-gradient(135deg,#C98A34,#C0455A 55%,#3563C9)}
.web .carddetail .detail-photo{aspect-ratio:16/10}
.carddetail .detail-photo .slot{position:absolute;inset:0;background-size:cover;background-position:center}
.carddetail .detail-photo .placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:rgba(255,255,255,.9);text-align:center;padding:24px}
.carddetail .detail-photo .placeholder svg{width:30px;height:30px;opacity:.9}
.carddetail .detail-photo .placeholder .pt{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;line-height:1.5;max-width:240px}
.carddetail .detail-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4),transparent 35%)}
.carddetail .detail-photo .dp-top{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;gap:8px;padding:14px}
.carddetail .detail-photo .dp-top .chip{color:#fff;border-color:rgba(255,255,255,.4);background:rgba(0,0,0,.25);backdrop-filter:blur(8px)}
.carddetail .detail-photo .dp-top .chip.cat{border-color:rgba(255,255,255,.7)}
.opt .bar .fill{position:absolute;inset:0 auto 0 0;border-radius:6px;width:0;
  transition:width 1s cubic-bezier(.22,1,.36,1)}
.opt .bar .ghost{position:absolute;top:50%;transform:translateY(-50%);width:2px;height:13px;border-radius:2px;
  background:var(--ink);opacity:.32}
.opt .tickmark{position:absolute;top:50%;left:50%;width:30px;height:30px;border-radius:50%;
  background:var(--solid-ink);color:var(--on-solid);display:grid;place-items:center;z-index:5;pointer-events:none;
  opacity:0;transform:translate(-50%,-50%) scale(.4)}
.opt .tickmark svg{width:17px;height:17px}
.opt .tickmark.flash{animation:flashcheck 1.1s ease}
@keyframes flashcheck{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}16%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}30%{opacity:1;transform:translate(-50%,-50%) scale(1)}66%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.12)}}
/* during-hold highlight only */
.opt.caret{background:var(--surface-sunken)}
.opt.caret .ph{box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),0 0 0 2px var(--ink);transform:scale(1.04)}
.bars .caret-arrow{position:absolute;left:-3px;width:0;height:0;pointer-events:none;
  border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:8px solid var(--ink);
  transform:translateY(-50%);transition:top .12s cubic-bezier(.22,1,.36,1);z-index:4}

/* =====================================================
   COVER CARD — image backdrop, chart slides up over it
   ===================================================== */
.cover{position:relative;border-radius:24px;overflow:hidden;transform:translateZ(0);isolation:isolate;border:1px solid var(--hair)}
.cover-img{position:absolute;inset:0;z-index:0;overflow:hidden;transform-origin:center;
  background:linear-gradient(135deg,#C98A34 0%,#C0455A 48%,#3563C9 100%);
  transition:filter .55s ease, transform .55s ease;
  filter:blur(28px) saturate(1.4);transform:scale(1.25)}
.cover-img .slot{position:absolute;inset:0;background-size:cover;background-position:center}
.cover-img .placeholder{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:rgba(255,255,255,.82);text-align:center;padding:24px}
.cover-img .placeholder svg{width:30px;height:30px;opacity:.85}
.cover-img .placeholder .pt{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;line-height:1.5;max-width:230px}
.cover-img::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.06) 30%,rgba(0,0,0,0) 55%)}
/* blur toggled by a class (robust, no :has dependency): default UP = blurred, revealed = sharp */
.cover.revealed .cover-img{filter:none;transform:scale(1)}

/* the sliding chart panel — in NORMAL FLOW so the card grows to fit content (no upward clip); photo band via margin-top */
.sheet{
  position:relative;z-index:6;margin-top:8px;
  background:var(--surface);
  border-top:1px solid var(--hair);
  border-radius:22px 22px 0 0;
  box-shadow:none;
  transition:transform .55s cubic-bezier(.22,1,.36,1);
  will-change:transform;
  padding:18px 18px 16px;
}
.web .sheet{padding:22px 22px 18px;margin-top:8px}
.sheet.up{transform:translateY(0)}
.sheet.down{transform:translateY(calc(100% - 134px))}   /* collapsed: author + title + #·local */
.web .sheet.down{transform:translateY(calc(100% - 118px))}
.sheet-handle{position:absolute;top:0;left:0;right:0;height:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3}
.sheet-handle .chev{display:grid;place-items:center;color:var(--hair-2);transform:rotate(180deg);transition:transform .35s,color .15s}
.sheet-handle:hover .chev{color:var(--ink-3)}
.sheet-handle .chev svg{width:18px;height:18px;display:block}
.sheet.down .sheet-handle .chev{transform:rotate(0deg)}

/* =====================================================
   FOOTER metrics + audit/ledger trigger
   ===================================================== */
/* discreet meta line under the title */
.subline{display:flex;align-items:center;flex-wrap:wrap;gap:5px 12px;margin:7px 0 2px;
  font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:.01em}
.subline .htag{color:var(--ink-3);font-weight:600}
.subline .loc{display:inline-flex;align-items:center;gap:3px;color:var(--ink-3);
  border:0;background:transparent;padding:0;border-radius:0}
.subline .loc svg{width:10px;height:10px;fill:currentColor;opacity:.9}

.cfoot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px 14px;margin-top:13px;padding-top:13px;border-top:1px solid var(--hair)}
.regbox{display:flex;align-items:center;gap:8px;min-width:0}
.ic-bare{background:none;border:0;padding:3px;cursor:pointer;color:var(--ink-2);display:grid;place-items:center;
  flex:0 0 auto;transition:color .15s,transform .12s}
.ic-bare:hover{color:var(--ink)}
.ic-bare:active{transform:scale(.88)}
.ic-bare svg{width:18px;height:18px;display:block}
.regbtn{color:var(--ink-2)}
@keyframes regpulse{0%{transform:scale(1);color:var(--ink-2)}35%{transform:scale(1.28);color:var(--p-blue)}100%{transform:scale(1);color:var(--ink-2)}}
.regbtn.pulse{animation:regpulse .9s ease}
.regmeta{display:flex;flex-direction:column;line-height:1.25;font-family:var(--font-mono);min-width:0;margin-left:2px}
.regmeta .rvotes{font-size:11px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.regmeta .rtoken{font-size:10px;color:var(--ink-3);font-variant-numeric:tabular-nums;white-space:nowrap}
.cfoot .grow{flex:1}
/* press-and-hold choice button (fingerprint) */
.choice-dock{display:inline-flex;align-items:center;gap:9px;flex:0 0 auto}
.choice{width:44px;height:44px;border-radius:50%;flex:0 0 auto;cursor:pointer;
  background:var(--solid-ink);color:var(--on-solid);border:0;display:grid;place-items:center;
  box-shadow:var(--shadow-md);touch-action:none;user-select:none;-webkit-user-select:none;
  transition:transform .14s cubic-bezier(.22,1,.36,1),filter .15s}
.choice svg{width:22px;height:22px}
.choice:hover{filter:brightness(.92)}
.card.choosing .choice{transform:scale(1.12)}
.choice.voted{background:var(--solid-ink);color:var(--on-solid);box-shadow:var(--shadow-md)}
.choice.voted svg{width:21px;height:21px}

/* (legacy vote button / radios removed — choice is now press-and-hold) */

/* =====================================================
   CYCLIC LINE CHART (tracking — points & line per cycle)
   ===================================================== */
.tracking{margin-top:10px}
.track-legend{display:flex;flex-wrap:wrap;gap:12px 16px;margin-bottom:12px}
.track-legend .lg{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink)}
.track-legend .lg .dot{width:10px;height:10px;border-radius:50%}
.track-legend .lg .val{font-family:var(--font-mono);font-size:11px;color:var(--ink-2);font-weight:600;margin-left:2px}
.track-legend .lg .delta{font-family:var(--font-mono);font-size:10px;font-weight:600;padding:1px 5px;border-radius:5px}
.delta.up{color:var(--p-green);background:rgba(44,140,106,.12)}
.delta.dn{color:var(--p-crimson);background:rgba(192,69,90,.12)}
.chartwrap{position:relative;border-radius:14px;background:var(--surface-sunken);border:1px solid var(--hair);
  height:150px;cursor:ew-resize;touch-action:none;overflow:hidden}
.web .chartwrap{height:180px}
.chartwrap svg{position:absolute;inset:0;display:block;width:100%;height:100%}
.tlayer{position:absolute;inset:0;pointer-events:none}
.tguide{position:absolute;top:8%;bottom:20%;width:1px;background:var(--hair-2);transform:translateX(-50%);transition:left .12s ease}
.tdot{position:absolute;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%);
  background:var(--c);transition:width .12s,height .12s}
.tdot.on{width:9px;height:9px;background:var(--c)}
.chart-x{display:flex;justify-content:space-between;margin-top:9px;padding:0 4px}
.chart-x span{font-family:var(--font-mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.02em;transition:color .12s;white-space:nowrap}
.chart-x span.now{color:var(--ink);font-weight:600}
.track-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:10px}
.track-foot .tcaption{font-family:var(--font-mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-foot .tcount{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--ink-2);font-variant-numeric:tabular-nums;white-space:nowrap}

/* columns (first cycle of a cyclic poll) */
.cols{display:flex;align-items:flex-end;gap:14px;height:150px;padding:0 4px;margin-top:6px}
.col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:8px;height:100%}
.col .colbar{width:100%;max-width:54px;border-radius:8px 8px 0 0;min-height:4px;
  transition:height 1s cubic-bezier(.22,1,.36,1)}
.col .colval{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--ink)}
.col .collab{font-size:10.5px;font-weight:600;color:var(--ink-2);text-align:center;line-height:1.15}
.firstcycle-tag{font-family:var(--font-mono);font-size:9.5px;color:var(--ink-3);margin-top:10px;text-align:center;letter-spacing:.04em}

/* =====================================================
   LEDGER / RECEIPT overlay (Ethereum-style, discreet)
   ===================================================== */
.ledger-sheet{
  position:absolute;inset:0;z-index:80;display:flex;align-items:flex-end;
  background:rgba(0,0,0,.34);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.ledger-sheet.open{opacity:1;pointer-events:auto}
.ledger-card{
  width:100%;background:var(--surface);border-radius:26px 26px 0 0;
  border-top:1px solid var(--hair-2);box-shadow:var(--shadow-lg);
  transform:translateY(18px);transition:transform .35s cubic-bezier(.22,1,.36,1);
  padding:20px 20px 26px;max-height:86%;overflow:auto;
}
.web .ledger-card{border-radius:26px;max-width:520px;margin:auto;transform:translateY(0) scale(.96);align-self:center}
.ledger-sheet.open .ledger-card{transform:translateY(0) scale(1)}
.ledger-grip{width:38px;height:4px;border-radius:3px;background:var(--hair-2);margin:0 auto 16px}
.ledger-check{width:46px;height:46px;border-radius:14px;background:var(--solid-ink);color:var(--on-solid);
  display:grid;place-items:center;margin-bottom:14px}
.ledger-check svg{width:24px;height:24px}
.ledger-card h3{font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:5px}
.ledger-card .sub{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-bottom:16px;max-width:400px}
.receipt{border:1px solid var(--hair);border-radius:14px;overflow:hidden;background:var(--surface-2)}
.receipt .rrow{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--hair)}
.receipt .rrow:last-child{border-bottom:0}
.receipt .rk{font-family:var(--font-mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.receipt .rv{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.receipt .rv.token{color:var(--ink);display:inline-flex;align-items:center;gap:7px}
.receipt .rv .new{font-size:8.5px;font-weight:700;letter-spacing:.08em;color:var(--p-green);
  border:1px solid currentColor;border-radius:5px;padding:2px 5px}

.chain{margin-top:14px;border-top:1px solid var(--hair);padding-top:14px}
.chain .ctitle{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.chain .ctitle .ok{color:var(--p-green);display:inline-flex;align-items:center;gap:5px}
.chain .ctitle .ok svg{width:12px;height:12px}
.chain .cline{display:flex;align-items:center;gap:10px;padding:7px 0;font-family:var(--font-mono);font-size:11px;color:var(--ink-2);font-variant-numeric:tabular-nums}
.chain .cline .idx{color:var(--ink-3);width:46px}
.chain .cline .hash{color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chain .cline .link{width:14px;height:1px;background:var(--hair-2);flex:0 0 auto}
.chain .cline.mine{color:var(--ink)}
.chain .cline.mine .hash{font-weight:700}
.chain .cline.mine::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--p-green);flex:0 0 auto;
  box-shadow:0 0 0 3px rgba(44,140,106,.18)}
.ledger-card .lact{display:flex;gap:10px;margin-top:18px}
.ledger-card .lact button,.ledger-card .lact .primary{flex:1;border-radius:12px;padding:13px;font-family:var(--font-ui);font-weight:700;font-size:13.5px;cursor:pointer;border:1px solid var(--hair-2);background:transparent;color:var(--ink)}
.ledger-card .lact button:hover,.ledger-card .lact .primary:hover{background:var(--surface-sunken)}
.ledger-card .lact .primary{background:var(--solid-ink);color:var(--on-solid);border-color:var(--solid-ink)}
.ledger-card .lact .primary:hover{filter:brightness(.94);background:var(--solid-ink)}

/* bottom nav (mobile) */
.bnav{
  position:absolute;left:0;right:0;bottom:0;z-index:40;
  display:flex;align-items:center;justify-content:space-around;
  padding:9px 14px calc(9px + env(safe-area-inset-bottom,12px));
  background:var(--glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border-top:1px solid var(--hair);
}
.bnav .bn{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ink-3);cursor:pointer;background:none;border:0;
  font-family:var(--font-mono);font-size:8.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.bnav .bn svg{width:21px;height:21px}
.bnav .bn.on{color:var(--ink)}
.bnav .bn.create{color:var(--on-solid)}
.bnav .bn.create .ic{width:44px;height:44px;border-radius:15px;background:var(--solid-ink);display:grid;place-items:center;margin-bottom:0;box-shadow:var(--shadow-md)}
.bnav .bn.create .ic svg{width:22px;height:22px}

/* variation gallery cards (outside frames) */
.varGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px}
.varCard{background:#fff;border:1px solid var(--page-hair);border-radius:20px;padding:20px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.varCard .vh{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--page-ink2);margin-bottom:4px}
.varCard .vd{font-size:13px;color:#52525a;margin-bottom:16px;line-height:1.45}
.varStage{border-radius:16px;overflow:hidden}
