/* ===========================================================
   PESKEL — Perfil (pessoa física + organização/CNPJ)
   Privacy-first: mostra participação, nunca o voto. Scoped under .pf
   =========================================================== */
.pf{position:relative;height:100%;background:var(--bg);color:var(--ink);font-family:var(--font-ui);display:flex;flex-direction:column}

/* top bar */
.pf .topbar{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:13px 16px;
  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 .pf .topbar{padding:14px 24px}
.pf .brand{display:flex;align-items:center;gap:10px}
.pf .brand .word{font-size:21px;font-weight:800;letter-spacing:-.045em}
.web .pf .brand .word{font-size:23px}
.pf .spacer{flex:1}
.pf .web-nav{display:none;gap:6px}
.web .pf .web-nav{display:flex}
.pf .web-nav a{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-2);text-decoration:none;white-space:nowrap;padding:8px 13px;border-radius:9px;transition:background .15s,color .15s;cursor:pointer}
.pf .web-nav a:hover{background:var(--surface-sunken);color:var(--ink)}
.pf .web-nav a.on{color:var(--ink);background:var(--surface-sunken)}
.pf .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}
.pf .icon-btn:hover{background:var(--surface-sunken)}
.pf .icon-btn svg{width:17px;height:17px}

.pf .scroll{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.pf .scroll::-webkit-scrollbar{width:0;height:0}
.pbody{padding-bottom:96px}
.web .pbody{padding-bottom:48px;max-width:920px;margin:0 auto}

/* ===== cover band + header ===== */
.pcover{height:104px;background:linear-gradient(120deg,#1b1b20,#2a2a31 60%,#15151a);position:relative}
.web .pcover{height:150px;border-radius:0}
.pcover .cnote{position:absolute;right:12px;bottom:9px;font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;
  text-transform:uppercase;color:rgba(255,255,255,.5)}
.phead{padding:0 18px;margin-top:-34px;position:relative}
.web .phead{padding:0 28px;margin-top:-44px}
.pava{width:84px;height:84px;border-radius:50%;background:var(--surface-sunken);border:4px solid var(--bg);
  display:grid;place-items:center;font-size:30px;font-weight:800;color:var(--ink-2);overflow:hidden;position:relative}
.web .pava{width:108px;height:108px;font-size:38px}
.pava .org-tile{position:absolute;inset:0;display:grid;place-items:center;background:var(--solid-ink);color:var(--on-solid)}
.pava .org-tile svg{width:42px;height:42px}
.web .pava .org-tile svg{width:54px;height:54px}

.pident{display:flex;align-items:flex-start;gap:14px;margin-top:10px}
.pident .pmain{min-width:0;flex:1}
.pname{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.web .pname{font-size:26px}
.pname .vbadge{display:inline-grid;place-items:center;color:var(--ink);flex:0 0 auto}
.pname .vbadge svg{width:19px;height:19px}
.phandle{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-3);margin-top:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.phandle .kind{color:var(--ink-2);border:1px solid var(--hair-2);border-radius:6px;padding:2px 7px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.pbio{font-size:14px;line-height:1.5;color:var(--ink-2);margin-top:11px;max-width:560px;text-wrap:pretty}
.pmeta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:10px;font-family:var(--font-mono);font-size:11.5px;color:var(--ink-3)}
.pmeta .mi{display:inline-flex;align-items:center;gap:5px}
.pmeta .mi svg{width:13px;height:13px;opacity:.85}
.pmeta .mi a{color:var(--ink-2);text-decoration:none}
.pmeta .mi a:hover{color:var(--ink)}

.pactions{display:flex;gap:9px;flex-shrink:0;margin-top:34px}
.web .pactions{margin-top:52px}
.pbtn{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:9px 16px;cursor:pointer;
  font-family:var(--font-ui);font-weight:700;font-size:13px;letter-spacing:-.01em;border:1px solid var(--hair-2);
  background:transparent;color:var(--ink);transition:background .15s,filter .15s}
.pbtn:hover{background:var(--surface-sunken)}
.pbtn svg{width:15px;height:15px}
.pbtn.primary{background:var(--solid-ink);color:var(--on-solid);border-color:var(--solid-ink)}
.pbtn.primary:hover{filter:brightness(.92);background:var(--solid-ink)}
.pbtn.icon{padding:9px;width:38px;justify-content:center}

/* ===== stats strip ===== */
.pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair);
  border:1px solid var(--hair);border-radius:16px;overflow:hidden;margin:18px 18px 0}
.pstats.pstats-pf{grid-template-columns:repeat(2,1fr)}
.web .pstats{margin:22px 28px 0;grid-template-columns:repeat(4,1fr)}
.web .pstats.pstats-pf{grid-template-columns:repeat(4,1fr)}
.pstat{background:var(--surface);padding:14px 14px;display:flex;flex-direction:column;gap:3px;cursor:default}
.pstat.link{cursor:pointer;transition:background .15s}
.pstat.link:hover{background:var(--surface-sunken)}
.pstat .sv{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1;display:flex;align-items:center;gap:6px}
.web .pstat .sv{font-size:23px}
.pstat .sv .rkbadge{font-size:10px;font-weight:700;color:var(--on-solid);background:var(--solid-ink);border-radius:6px;padding:2px 6px;letter-spacing:0}
.pstat .sk{font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.pstat .sk .arrow{opacity:.6}

/* ===== tabs ===== */
.ptabs{display:flex;gap:4px;padding:18px 18px 0;border-bottom:1px solid var(--hair);position:sticky;top:0;background:var(--bg);z-index:5}
.web .ptabs{padding:24px 28px 0}
.ptab{font-family:var(--font-ui);font-size:13.5px;font-weight:600;letter-spacing:-.01em;color:var(--ink-2);
  background:transparent;border:0;cursor:pointer;padding:10px 4px;margin:0 10px 0 0;position:relative;transition:color .15s;white-space:nowrap}
.ptab:hover{color:var(--ink)}
.ptab.on{color:var(--ink)}
.ptab .pc{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);margin-left:5px}
.ptab.on::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--ink);border-radius:2px}

/* ===== content ===== */
.ptabbody{padding:16px 18px 0}
.web .ptabbody{padding:20px 28px 0}
.pgrid{display:grid;gap:14px}
.web .pgrid{grid-template-columns:1fr 1fr}

/* mini poll card (created polls) */
.mpoll{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:15px 16px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:11px;cursor:pointer;transition:box-shadow .2s,border-color .2s}
.mpoll:hover{box-shadow:var(--shadow-md)}
.mpoll .mtop{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;color:var(--ink-3);letter-spacing:.02em}
.mpoll .mtag{color:var(--ink-2);font-weight:600}
.mpoll .mloc{display:inline-flex;align-items:center;gap:3px}
.mpoll .mloc svg{width:10px;height:10px;fill:currentColor}
.mpoll .mstatus{margin-left:auto;display:inline-flex;align-items:center;gap:5px}
.mpoll .mstatus .dot{width:6px;height:6px;border-radius:50%}
.mpoll .mstatus .dot.open{background:var(--p-blue)}
.mpoll .mstatus .dot.closed{background:var(--ink-3);opacity:.5}
.mpoll .mq{font-size:15px;font-weight:700;letter-spacing:-.015em;line-height:1.25;color:var(--ink);text-wrap:balance}
.mpoll .mbars{display:flex;flex-direction:column;gap:5px}
.mpoll .mbar{height:5px;border-radius:4px;background:var(--track);overflow:hidden;position:relative}
.mpoll .mbar i{position:absolute;inset:0 auto 0 0;border-radius:4px}
.mpoll .mfoot{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);padding-top:3px}
.mpoll .mfoot b{color:var(--ink-2);font-weight:600}
.mpoll .mfoot . chip{margin-left:auto}
.mpoll .priv{display:inline-flex;align-items:center;gap:4px;color:var(--ink-3)}
.mpoll .priv svg{width:11px;height:11px}

/* ===== achievements ===== */
.medals{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.medal{background:var(--surface);border:1px solid var(--hair);border-radius:14px;padding:15px;display:flex;flex-direction:column;gap:9px}
.medal.locked{opacity:.5}
.medal .mic{width:40px;height:40px;border-radius:12px;background:var(--surface-sunken);display:grid;place-items:center;color:var(--ink)}
.medal.earned .mic{background:var(--solid-ink);color:var(--on-solid)}
.medal .mic svg{width:21px;height:21px}
.medal .mname{font-size:13.5px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.medal .mdesc{font-size:11.5px;line-height:1.4;color:var(--ink-3)}
.medal .mwhen{font-family:var(--font-mono);font-size:9.5px;color:var(--ink-3);letter-spacing:.03em}

/* ===== privacy note (records) ===== */
.precords{display:flex;flex-direction:column;gap:14px}
.privacy-card{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:18px}
.privacy-card h3{font-size:15px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;margin-bottom:7px}
.privacy-card h3 svg{width:17px;height:17px}
.privacy-card p{font-size:13px;line-height:1.55;color:var(--ink-2);max-width:560px}
.privacy-card .pgo{margin-top:14px;display:inline-flex;align-items:center;gap:8px;background:var(--solid-ink);color:var(--on-solid);
  border:0;border-radius:11px;padding:11px 16px;cursor:pointer;font-family:var(--font-ui);font-weight:700;font-size:13px;text-decoration:none}
.privacy-card .pgo svg{width:14px;height:14px}
.tokrow{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--hair);border-radius:11px;background:var(--surface-2);
  font-family:var(--font-mono);font-size:11.5px;color:var(--ink-2)}
.tokrow .tk{color:var(--ink);font-weight:600}
.tokrow .tw{margin-left:auto;color:var(--ink-3)}

/* org: alcance highlight */
.reach{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:18px;display:flex;align-items:center;gap:16px;margin-bottom:14px}
.reach .rbig{font-family:var(--font-mono);font-size:30px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.reach .rl{font-size:13px;color:var(--ink-2);line-height:1.4}
.reach .rl b{color:var(--ink);font-weight:600}
.orgnote-card{display:flex;align-items:flex-start;gap:9px;background:var(--surface-sunken);border-radius:12px;padding:13px 15px;
  font-size:12.5px;line-height:1.5;color:var(--ink-2);margin:0 18px}
.web .orgnote-card{margin:0 28px}
.orgnote-card svg{width:15px;height:15px;flex:0 0 auto;margin-top:1px;color:var(--ink)}

/* empty */
.pempty{text-align:center;padding:36px 20px;color:var(--ink-3);font-size:13px}

/* bottom nav */
.pf .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)}
.pf .bnav .bn{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ink-3);cursor:pointer;background:none;border:0;text-decoration:none;
  font-family:var(--font-mono);font-size:8.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.pf .bnav .bn svg{width:21px;height:21px}
.pf .bnav .bn.on{color:var(--ink)}
.pf .bnav .bn.create{color:var(--on-solid)}
.pf .bnav .bn.create .ic{width:44px;height:44px;border-radius:15px;background:var(--solid-ink);display:grid;place-items:center;box-shadow:var(--shadow-md)}
.pf .bnav .bn.create .ic svg{width:22px;height:22px}

/* toast */
.pftoast{position:absolute;left:50%;bottom:84px;transform:translateX(-50%) translateY(12px);z-index:90;
  background:var(--solid-ink);color:var(--on-solid);font-family:var(--font-mono);font-size:11px;font-weight:600;
  padding:9px 15px;border-radius:999px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;white-space:nowrap}
.web .pftoast{bottom:24px}
.pftoast.show{opacity:1;transform:translateX(-50%) translateY(0)}
