:root{
  --bg:#07070a; --bg2:#121218; --card:#16161d; --card2:#1e1e27;
  --line:#2a2a35; --line2:#36363f; --txt:#f4f4f7; --mut:#9a9aa6; --mut2:#62626e;
  --green:#19cf78; --green2:#0e9a57; --gold:#f5c542; --red:#e0524a;
  --blue:#3b7bff; --rep:#8a6bff; --rep2:#6a45ff;
  --grad:linear-gradient(92deg,#19cf78,#3b7bff 60%,#8a6bff);
  --safe-top:env(safe-area-inset-top); --safe-bot:env(safe-area-inset-bottom);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  background:var(--bg); color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  overscroll-behavior-y:none; -webkit-font-smoothing:antialiased;
}
.hidden{display:none!important}

.wordmark{font-weight:900;letter-spacing:-.5px;font-size:19px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.wordmark.big{font-size:34px;margin:6px 0 2px}

/* ---------- LOGIN ---------- */
.login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(130% 90% at 50% -10%,#142a52 0%,#0a0f1f 45%,#07070a 75%)}
.login-card{width:100%;max-width:380px;background:rgba(22,22,29,.86);border:1px solid var(--line);
  border-radius:26px;padding:34px 26px;text-align:center;box-shadow:0 24px 70px rgba(0,0,0,.6);
  backdrop-filter:blur(10px)}
.login-logo{font-size:52px;line-height:1}
.login-logo-img{width:120px;height:120px;object-fit:contain;border-radius:24px;
  box-shadow:0 14px 40px rgba(0,0,0,.45);margin-bottom:4px}
.login-card .sub{color:var(--mut);font-size:14px;margin-bottom:24px}
.login-card form{display:flex;flex-direction:column;gap:12px}
.login-card input{background:var(--bg2);border:1px solid var(--line);border-radius:14px;
  padding:15px 16px;color:var(--txt);font-size:16px}
.login-card input:focus{outline:none;border-color:var(--blue)}
.login-card button{background:var(--grad);color:#fff;border:none;border-radius:14px;
  padding:15px;font-size:17px;font-weight:800;margin-top:4px;box-shadow:0 8px 24px rgba(59,123,255,.3)}
.login-card button:active{transform:scale(.98)}
.err{color:var(--red);font-size:14px;min-height:18px}
.hint{color:var(--mut2);font-size:13px;margin-top:18px}

/* ---------- TOPBAR ---------- */
.app{padding-bottom:calc(76px + var(--safe-bot))}
.topbar{position:sticky;top:0;z-index:30;
  background:linear-gradient(180deg,rgba(10,12,22,.96),rgba(7,7,10,.96));
  padding:calc(12px + var(--safe-top)) 16px 14px;border-bottom:1px solid var(--line);
  backdrop-filter:blur(12px)}
.topbar-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.shared-badge{font-size:11.5px;color:var(--mut);margin-top:4px}
.shared-badge span{color:var(--green);font-weight:700}
.gear{background:var(--card2);border:1px solid var(--line);color:var(--txt);width:40px;height:40px;
  border-radius:12px;font-size:18px}
.gear:active{transform:scale(.94)}
.prog-row{display:flex;align-items:center;gap:14px;margin-top:14px}
.pct{font-size:30px;font-weight:900;background:var(--grad);-webkit-background-clip:text;
  background-clip:text;color:transparent;min-width:74px}
.prog-meta{flex:1}
.progress{height:9px;background:var(--bg2);border-radius:99px;overflow:hidden;border:1px solid var(--line)}
.progress-fill{height:100%;width:0;background:var(--grad);border-radius:99px;transition:width .5s cubic-bezier(.3,1,.4,1)}
.counts{font-size:12px;color:var(--mut);margin-top:6px}

/* ---------- CONTROLS ---------- */
.controls{position:sticky;top:0;z-index:20;padding:10px 16px 6px;
  background:linear-gradient(180deg,var(--bg) 70%,transparent)}
.search-wrap{position:relative}
.search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.6}
.search-wrap input{width:100%;background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:12px 14px 12px 38px;color:var(--txt);font-size:15px}
.search-wrap input:focus{outline:none;border-color:var(--blue)}
.sortbar{display:flex;align-items:center;gap:6px;margin-top:9px;overflow-x:auto;scrollbar-width:none}
.sortbar::-webkit-scrollbar{display:none}
.sortlabel{font-size:11px;color:var(--mut2);text-transform:uppercase;letter-spacing:.5px;margin-right:2px}
.seg{background:var(--card);border:1px solid var(--line);color:var(--mut);border-radius:99px;
  padding:7px 14px;font-size:13px;font-weight:700;white-space:nowrap}
.seg.active{background:var(--card2);border-color:var(--green);color:var(--green)}

/* ---------- VIEW ---------- */
main{padding:6px 12px 24px}
.section{background:var(--card);border:1px solid var(--line);border-radius:18px;margin:10px 0;overflow:hidden;
  transition:border-color .2s}
.section.complete{border-color:rgba(25,207,120,.4)}
.section-head{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer}
.flag{font-size:26px;line-height:1;width:34px;text-align:center}
.sec-info{flex:1;min-width:0}
.sec-name{font-size:16px;font-weight:700}
.sec-code{font-size:12px;color:var(--mut);margin-top:1px}
.sec-code .reppill{color:var(--rep);font-weight:700}
.sec-count{font-size:14px;font-weight:800;color:var(--mut)}
.sec-count.done{color:var(--green)}
.sec-count .ck{margin-left:4px}
.chev{color:var(--mut2);font-size:13px;transition:transform .2s}
.section.open .chev{transform:rotate(90deg)}
.sec-bar{height:4px;background:var(--bg2)}
.sec-bar-fill{height:100%;background:var(--grad);border-radius:0 99px 99px 0;transition:width .4s}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(54px,1fr));gap:8px;
  padding:8px 14px 16px;display:none}
.grid.named{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}
.section.open .grid{display:grid}
.cell{aspect-ratio:1/1.16;border-radius:13px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:2px;font-size:17px;font-weight:800;position:relative;user-select:none;
  border:2px solid var(--line);background:var(--card2);color:var(--mut2)}
.cell .cap{font-size:8.5px;font-weight:600;color:var(--mut2);line-height:1.05;text-align:center;
  padding:0 3px;max-height:20px;overflow:hidden}
.cell.have{background:linear-gradient(160deg,var(--green),var(--green2));border-color:transparent;color:#04150c}
.cell.have .cap{color:#063a22}
.cell.rep{background:linear-gradient(160deg,#9a7bff,var(--rep2));border-color:transparent;color:#fff}
.cell.rep .cap{color:#e9e2ff}
.cell .badge{position:absolute;top:-6px;right:-6px;background:var(--gold);color:#1a1200;
  font-size:11px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;
  align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 4px rgba(0,0,0,.5)}
.cell .ckmark{position:absolute;top:4px;left:5px;font-size:10px;opacity:.85}
.cell:active{transform:scale(.92)}

/* ---------- FALTAM / TROCAR ---------- */
.listcard{background:var(--card);border:1px solid var(--line);border-radius:16px;margin:10px 0;padding:6px 0}
.listcard h3{font-size:14px;padding:11px 16px 6px;color:var(--txt);display:flex;gap:8px;align-items:center;font-weight:700}
.listcard h3 small{margin-left:auto;color:var(--mut);font-weight:600}
.chiprow{display:flex;flex-wrap:wrap;gap:8px;padding:6px 14px 14px}
.chip{background:var(--card2);border:2px solid var(--line);border-radius:12px;padding:8px 12px;
  font-weight:800;font-size:15px;color:var(--txt);display:flex;align-items:center;gap:6px}
.chip small{color:var(--mut);font-weight:600;font-size:12px}
.chip.rep{border-color:transparent;background:linear-gradient(160deg,#9a7bff,var(--rep2));color:#fff}
.empty{text-align:center;color:var(--mut2);padding:54px 24px;font-size:15px;line-height:1.6}
.bigstat{text-align:center;padding:18px 18px 6px}
.bigstat .n{font-size:42px;font-weight:900;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.bigstat .l{color:var(--mut);font-size:14px}

/* ---------- STATS ---------- */
.ring-wrap{display:flex;justify-content:center;padding:18px 0 6px}
.ring{position:relative;width:170px;height:170px}
.ring svg{transform:rotate(-90deg)}
.ring .rtxt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .rtxt b{font-size:40px;font-weight:900;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ring .rtxt span{font-size:12px;color:var(--mut);margin-top:2px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px 4px 6px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center}
.kpi b{display:block;font-size:24px;font-weight:900}
.kpi.g b{color:var(--green)} .kpi.r b{color:var(--rep)} .kpi.y b{color:var(--gold)}
.kpi span{font-size:11px;color:var(--mut);margin-top:2px;display:block}
.statsec{margin-top:16px}
.statsec h4{font-size:13px;color:var(--mut);text-transform:uppercase;letter-spacing:.6px;margin:0 4px 8px}
.rankrow{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:13px;padding:10px 13px;margin:7px 0}
.rankrow .rk-flag{font-size:20px;width:26px;text-align:center}
.rankrow .rk-name{flex:1;font-size:14px;font-weight:600;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rankrow .rk-bar{width:84px;height:6px;background:var(--bg2);border-radius:99px;overflow:hidden}
.rankrow .rk-bar i{display:block;height:100%;background:var(--grad)}
.rankrow .rk-pct{font-size:13px;font-weight:800;color:var(--mut);min-width:38px;text-align:right}

/* ---------- MAPA / SEDES ---------- */
.mapahead{text-align:center;padding:16px 16px 8px}
.mapahead .ttl{font-size:20px;font-weight:900}
.mapahead .sb{color:var(--mut);font-size:13px;margin-top:4px}
.countryblk{margin-top:14px}
.countryblk .ch{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;margin:0 4px 8px}
.countryblk .ch small{color:var(--mut);font-weight:600;margin-left:auto}
.city{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:12px 14px;margin:8px 0}
.city .cdot{width:9px;height:9px;border-radius:50%;background:var(--grad);flex:none}
.city .cinfo{flex:1;min-width:0}
.city .cname{font-size:15px;font-weight:700}
.city .cstad{font-size:12px;color:var(--mut);margin-top:1px}

/* ---------- CONFIG (sheet body) ---------- */
.cfg-item{background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin:10px 0;
  display:flex;justify-content:space-between;align-items:center;gap:12px}
.cfg-item .k{font-size:12px;color:var(--mut)}
.cfg-item .v{font-size:15px;font-weight:600}
.btn{border:none;border-radius:13px;padding:14px 16px;font-size:15px;font-weight:800;width:100%;margin-top:8px}
.btn.logout{background:#2a1414;color:var(--red);border:1px solid #4a2222;margin-top:18px}
.btn.share{background:var(--grad);color:#fff}
.exp-title{font-size:15px;font-weight:800;margin:18px 2px 2px}
.exp-sub{font-size:12px;color:var(--mut);margin:0 2px 10px}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.expbtn{display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--card2);
  border:1px solid var(--line2);border-radius:15px;padding:15px 6px;color:var(--txt);font-size:14px;font-weight:800}
.expbtn span{font-size:24px;line-height:1}
.expbtn small{font-size:10px;color:var(--mut);font-weight:600}
.expbtn:active{transform:scale(.95);border-color:var(--green)}

/* ---------- BOTTOM NAV ---------- */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;
  background:rgba(10,10,14,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line);
  padding-bottom:var(--safe-bot)}
.nav-btn{flex:1;background:none;border:none;color:var(--mut2);font-size:10.5px;font-weight:700;
  padding:9px 0 8px;display:flex;flex-direction:column;align-items:center;gap:3px}
.nav-btn span{font-size:20px;filter:grayscale(.4);opacity:.7;transition:.15s}
.nav-btn.active{color:var(--green)}
.nav-btn.active span{filter:none;opacity:1;transform:translateY(-1px)}

/* ---------- SHEET ---------- */
.sheet{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end}
.sheet-bg{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.sheet-card{position:relative;width:100%;background:var(--bg2);border-radius:26px 26px 0 0;
  padding:14px 20px calc(28px + var(--safe-bot));border-top:1px solid var(--line2);
  animation:up .24s cubic-bezier(.3,1,.4,1);max-height:84vh;overflow-y:auto}
.sheet-grip{width:40px;height:4px;border-radius:99px;background:var(--line2);margin:0 auto 14px}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-title{font-size:19px;font-weight:800;text-align:center}
.sheet-sub{font-size:13px;color:var(--mut);text-align:center;margin-top:3px;margin-bottom:16px;min-height:16px}
.stepper{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:20px}
.stepper button{width:58px;height:58px;border-radius:50%;border:none;font-size:28px;font-weight:700;
  background:var(--card2);color:var(--txt)}
.stepper button:active{transform:scale(.92)}
.stepper-val{font-size:42px;font-weight:900;min-width:64px;text-align:center}
.sheet-actions{display:flex;gap:12px}
.sheet-actions button{flex:1;border:none;border-radius:14px;padding:15px;font-size:16px;font-weight:800}
.sheet-actions .ghost{background:var(--card2);color:var(--txt)}
.sheet-actions .primary{background:var(--grad);color:#fff}
.sheet-note{text-align:center;color:var(--mut2);font-size:12px;margin-top:14px;min-height:16px}

.toast{position:fixed;left:50%;bottom:calc(86px + var(--safe-bot));transform:translateX(-50%);
  background:var(--card2);color:var(--txt);padding:10px 18px;border-radius:99px;font-size:14px;
  border:1px solid var(--line2);z-index:80;opacity:0;transition:opacity .2s;pointer-events:none;
  max-width:88vw;text-align:center}
.toast.show{opacity:1}

/* ---------- SCAN FAB ---------- */
.scan-fab{position:fixed;right:16px;bottom:calc(80px + var(--safe-bot));z-index:45;
  display:flex;align-items:center;gap:8px;background:var(--grad);color:#fff;border:none;
  border-radius:99px;padding:13px 18px;font-size:15px;font-weight:800;
  box-shadow:0 10px 30px rgba(59,123,255,.45)}
.scan-fab:active{transform:scale(.95)}
.scan-fab .sf-ico{font-size:19px;line-height:1}

/* ---------- SCAN OVERLAY ---------- */
.scan{position:fixed;inset:0;z-index:70;background:var(--bg);display:flex;flex-direction:column;
  animation:up .26s cubic-bezier(.3,1,.4,1)}
.scan-head{display:flex;align-items:center;justify-content:space-between;
  padding:calc(14px + var(--safe-top)) 18px 12px;border-bottom:1px solid var(--line)}
.scan-ttl{font-size:18px;font-weight:800}
.scan-x{background:var(--card2);border:1px solid var(--line);color:var(--txt);width:36px;height:36px;
  border-radius:11px;font-size:16px}
.scan-x:active{transform:scale(.92)}
.scan-tabs{display:flex;gap:8px;padding:12px 18px}
.stab{flex:1;background:var(--card);border:1px solid var(--line);color:var(--mut);border-radius:13px;
  padding:11px;font-size:14px;font-weight:800}
.stab.active{background:var(--card2);border-color:var(--green);color:var(--green)}
.scan-body{flex:1;overflow-y:auto;padding:6px 18px calc(28px + var(--safe-bot))}

.scan-lbl{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;
  margin:14px 2px 7px}
.scan-sel{width:100%;background:var(--card);border:1px solid var(--line);border-radius:13px;
  padding:14px 14px;color:var(--txt);font-size:16px;-webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8'><path d='M1 1l5 5 5-5' stroke='%239a9aa6' stroke-width='2' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center}

/* quick grid */
.qhint{color:var(--mut);font-size:13px;text-align:center;padding:10px 8px;line-height:1.5}
.qgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:9px;padding:8px 0 4px}
.qcell{aspect-ratio:1/1.12;border-radius:13px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:2px;font-size:18px;font-weight:800;position:relative;user-select:none;
  border:2px solid var(--line);background:var(--card2);color:var(--mut)}
.qcell .qcap{font-size:8.5px;font-weight:600;line-height:1.05;text-align:center;padding:0 3px;
  max-height:20px;overflow:hidden;color:var(--mut2)}
.qcell.have{background:linear-gradient(160deg,var(--green),var(--green2));border-color:transparent;color:#04150c}
.qcell.have .qcap{color:#063a22}
.qcell.rep{background:linear-gradient(160deg,#9a7bff,var(--rep2));border-color:transparent;color:#fff}
.qcell.rep .qcap{color:#e9e2ff}
.qcell .qbadge{position:absolute;top:-6px;right:-6px;background:var(--gold);color:#1a1200;font-size:11px;
  font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;
  justify-content:center;padding:0 4px;box-shadow:0 1px 4px rgba(0,0,0,.5)}
.qcell:active{transform:scale(.9)}
.qbar{display:flex;gap:8px;margin-top:6px}
.qbar button{flex:1;border:none;border-radius:12px;padding:13px;font-size:14px;font-weight:800}
.qbar .undo{background:var(--card2);color:var(--txt);border:1px solid var(--line)}

/* camera */
.cam-wrap{position:relative;border-radius:18px;overflow:hidden;background:#000;margin-top:10px;
  aspect-ratio:3/4;display:flex;align-items:center;justify-content:center}
.cam-wrap video{width:100%;height:100%;object-fit:cover}
.cam-guide{position:absolute;left:8%;right:8%;top:38%;height:20%;border:2px solid rgba(255,255,255,.85);
  border-radius:10px;box-shadow:0 0 0 999px rgba(0,0,0,.35)}
.cam-guide::after{content:"alinhe o código aqui (ex: POR 15)";position:absolute;left:0;right:0;bottom:-26px;
  text-align:center;font-size:11px;color:#fff;opacity:.85}
.cam-off{color:var(--mut);font-size:14px;text-align:center;padding:30px 20px;line-height:1.6}
.cam-btns{display:flex;gap:10px;margin-top:12px}
.cam-btns button{flex:1;border:none;border-radius:14px;padding:15px;font-size:15px;font-weight:800}
.cam-btns .shoot{background:var(--grad);color:#fff}
.cam-btns .ghost{background:var(--card2);color:var(--txt);border:1px solid var(--line)}
.cam-status{text-align:center;color:var(--mut);font-size:13px;min-height:18px;margin-top:12px}
.cam-status.busy{color:var(--blue)}

/* OCR result confirm card */
.ocard{background:var(--card);border:1px solid var(--line2);border-radius:16px;padding:16px;margin-top:14px}
.ocard .obig{font-size:26px;font-weight:900;text-align:center}
.ocard .osub{font-size:13px;color:var(--mut);text-align:center;margin-top:3px}
.ocard .obtns{display:flex;gap:10px;margin-top:14px}
.ocard .obtns button{flex:1;border:none;border-radius:13px;padding:13px;font-size:15px;font-weight:800}
.ocard .obtns .ok{background:var(--grad);color:#fff}
.ocard .obtns .no{background:var(--card2);color:var(--txt);border:1px solid var(--line)}

/* feed of registered stickers */
.feed{margin-top:16px}
.feed h4{font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px;margin:0 2px 8px}
.feeditem{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);
  border-radius:13px;padding:11px 13px;margin:7px 0;animation:up .2s}
.feeditem .fflag{font-size:18px;width:24px;text-align:center}
.feeditem .fname{flex:1;min-width:0}
.feeditem .fname b{font-size:14px;font-weight:700}
.feeditem .fname small{display:block;font-size:11px;color:var(--mut)}
.feeditem .fstat{font-size:12px;font-weight:800;padding:5px 10px;border-radius:99px}
.feeditem .fstat.nova{background:rgba(25,207,120,.16);color:var(--green)}
.feeditem .fstat.rep{background:rgba(138,107,255,.18);color:var(--rep)}
.manual-row{display:flex;gap:8px;margin-top:8px}
.manual-row input{flex:1;background:var(--card);border:1px solid var(--line);border-radius:13px;
  padding:13px;color:var(--txt);font-size:16px}
.manual-row button{background:var(--grad);color:#fff;border:none;border-radius:13px;padding:0 18px;
  font-size:15px;font-weight:800}
