:root{
  --azul:#004e98;
  --azul-esc:#003a72;
  --azul-prof:#002b52;
  --azul-claro:#2d7dd2;
  --azul-bg:#eaf1f9;
  --ouro:#e8a33d;
  --ouro-esc:#c9852a;
  --verde:#2e9e6b;
  --verde-bg:#e6f5ee;
  --vermelho:#d65745;
  --bg:#f4f7fb;
  --surf:#ffffff;
  --tinta:#16202e;
  --tinta2:#5a6b7b;
  --borda:#dde5ee;
  --font-d:'Manrope';
  --font-b:'Inter';
  --sombra:0 1px 3px rgba(0,40,80,.06),0 6px 24px rgba(0,40,80,.05);
  --sombra-ft:0 8px 40px rgba(0,40,80,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-b),'Inter',sans-serif;background:var(--bg);color:var(--tinta);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.font-d{font-family:var(--font-d),sans-serif}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%}
.hidden{display:none!important}

/* ---------- TOPBAR ---------- */
.topbar{position:sticky;top:0;z-index:40;box-sizing:content-box;height:60px;background:var(--azul);display:flex;align-items:center;gap:18px;padding:env(safe-area-inset-top,0px) max(20px,env(safe-area-inset-right,0px)) 0 max(20px,env(safe-area-inset-left,0px));color:#fff;box-shadow:0 2px 10px rgba(0,40,80,.18)}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-d);font-weight:800;font-size:19px;letter-spacing:-.4px}
.logo-virbac{height:30px;width:auto;display:block;border-radius:4px}
.logo-vbc-chip{background:#fff;border-radius:8px;padding:5px 13px;display:inline-flex;align-items:center;flex-shrink:0;font-family:var(--font-d);font-weight:800;font-size:15px;color:#1a56a6;letter-spacing:-.3px;white-space:nowrap}
.logo .pod{font-weight:600;opacity:.92;font-size:15px;border-left:1px solid rgba(255,255,255,.35);padding-left:10px}
.topbar .spacer{flex:1}
.ava-menu{position:relative;flex-shrink:0}
.ava-dd{position:absolute;right:0;top:calc(100% + 10px);background:#fff;border-radius:12px;box-shadow:0 4px 32px rgba(0,40,80,.2);min-width:220px;overflow:hidden;display:none;z-index:200}
.ava-dd.show{display:block}
.ava-hd{padding:13px 16px 11px;background:var(--azul-bg);border-bottom:1px solid var(--borda)}
.ava-nome{font-weight:700;color:var(--tinta);font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ava-email{color:var(--tinta2);font-size:11.5px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ava-item{display:flex;align-items:center;gap:8px;padding:11px 16px;color:var(--tinta);font-size:13.5px;font-weight:500;text-decoration:none;transition:.12s}
.ava-item:hover{background:var(--azul-bg);color:var(--azul)}
.ava-sep{height:1px;background:var(--borda)}
.ava-sair{color:var(--vermelho)!important}
.ava-sair:hover{background:#fef2f0!important;color:var(--vermelho)!important}
.view-toggle{display:flex;background:rgba(255,255,255,.14);border-radius:9px;padding:3px}
.view-toggle button{color:rgba(255,255,255,.8);font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:7px;transition:.15s}
.view-toggle button.on{background:#fff;color:var(--azul)}
.pts-pill{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.14);border-radius:20px;padding:6px 13px 6px 11px;font-weight:700;font-family:var(--font-d)}
.pts-pill .coin{width:18px;height:18px;border-radius:50%;background:var(--ouro);display:grid;place-items:center;font-size:11px;color:#fff}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#2d7dd2,#004e98);display:grid;place-items:center;font-weight:700;font-size:13px;border:2px solid rgba(255,255,255,.4)}

/* ---------- LAYOUT ---------- */
.app{display:flex;min-height:calc(100vh - 60px - env(safe-area-inset-top,0px))}
.side{width:226px;background:var(--surf);border-right:1px solid var(--borda);padding:16px 12px;flex-shrink:0}
.side .grp{font-size:10.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--tinta2);padding:14px 12px 7px}
.nav-i{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:var(--tinta2);font-weight:600;font-size:13.5px;transition:.13s;width:100%;text-align:left}
.nav-i svg{width:18px;height:18px;flex-shrink:0}
.nav-i:hover{background:var(--azul-bg);color:var(--azul)}
.nav-i.on{background:var(--azul);color:#fff}
.nav-i .badge{margin-left:auto;background:var(--ouro);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 7px;font-family:var(--font-d)}
.nav-i.on .badge{background:#fff;color:var(--azul)}
.main{flex:1;padding:26px 30px;max-width:1100px}

/* ---------- MOBILE NAV (drawer + bottom nav) ---------- */
.hamb{display:none;width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.16);place-items:center;flex-shrink:0}
.hamb svg{width:21px;height:21px;color:#fff}
.drawer-ov{position:fixed;inset:0;background:rgba(10,28,48,.5);z-index:48;opacity:0;visibility:hidden;transition:.25s}
.drawer-ov.show{opacity:1;visibility:visible}
.botnav{display:none}
.g-split{display:grid;gap:16px;grid-template-columns:1.3fr 1fr}
.tcard{overflow:hidden}

@media(max-width:860px){
  .hamb{display:grid}
  .topbar{gap:9px;padding:0 12px}
  .logo .pod{display:none}
  .logo-vbc-chip{display:none}
  .logo{font-size:17px}
  .view-toggle button{padding:6px 11px;font-size:12px}
  .pts-pill{padding:6px 11px 6px 9px;font-size:13px}
  /* sidebar vira gaveta deslizante */
  .side{display:block;position:fixed;top:0;left:0;bottom:0;width:264px;z-index:50;transform:translateX(-100%);transition:transform .26s ease;overflow-y:auto;padding-top:calc(18px + env(safe-area-inset-top,0px));padding-left:max(12px,env(safe-area-inset-left,0px));box-shadow:4px 0 26px rgba(0,40,80,.18)}
  .side.hidden{display:none}
  .side.open{transform:translateX(0)}
  .main{padding:18px max(14px,env(safe-area-inset-right,0px)) calc(86px + env(safe-area-inset-bottom,0px)) max(14px,env(safe-area-inset-left,0px));max-width:100%}
  /* barra inferior */
  .botnav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid var(--borda);z-index:46;box-shadow:0 -2px 18px rgba(0,40,80,.08);padding:0 max(4px,env(safe-area-inset-right,0px)) env(safe-area-inset-bottom,0px) max(4px,env(safe-area-inset-left,0px));align-items:flex-start;padding-top:0}
  .bn-i{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--tinta2);font-size:9.5px;font-weight:600;padding:7px 1px;border-radius:10px;background:none}
  .bn-i svg{width:21px;height:21px}
  .bn-i.on{color:var(--azul)}
  .bn-fab{flex:0 0 auto;margin:0 3px;background:none;display:flex;flex-direction:column;align-items:center}
  .bn-fab .fab{width:52px;height:52px;border-radius:50%;background:var(--ouro);display:grid;place-items:center;box-shadow:0 7px 18px rgba(232,163,61,.5);transform:translateY(-13px);border:4px solid #fff}
  .bn-fab .fab svg{width:24px;height:24px;color:#fff}
  .bn-fab .lbl{font-size:9px;font-weight:700;color:var(--ouro-esc);transform:translateY(-10px)}
  /* tabelas rolam na horizontal */
  .tcard{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:600px}
}
@media(max-width:760px){.g-split{grid-template-columns:1fr}}
@media(max-width:600px){
  .campaign{flex-wrap:wrap}
  .campaign .cright{margin-left:0;width:100%;text-align:left;display:flex;align-items:baseline;gap:8px;margin-top:4px}
  .ocr-doc{flex-direction:column}
  .ocr-paper{width:100%}
}
@media(max-width:520px){
  .pod-col{max-width:108px}.pod-col .ct{font-size:10.5px}
  .review-pts .rt .v{font-size:25px}
}
@media(max-width:460px){.row2{grid-template-columns:1fr}}

/* ---------- COMPONENTES ---------- */
.page-head{margin-bottom:22px}
.page-head h1{font-size:25px;font-weight:800;letter-spacing:-.6px}
.page-head p{color:var(--tinta2);margin-top:3px;font-size:14px}
.card{background:var(--surf);border:1px solid var(--borda);border-radius:14px;box-shadow:var(--sombra)}
.pad{padding:20px}
.grid{display:grid;gap:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--azul);color:#fff;font-weight:700;font-size:13.5px;padding:11px 18px;border-radius:10px;transition:.15s;font-family:var(--font-d)}
.btn:hover{background:var(--azul-esc)}
.btn.ouro{background:var(--ouro)}.btn.ouro:hover{background:var(--ouro-esc)}
.btn.ghost{background:var(--azul-bg);color:var(--azul)}.btn.ghost:hover{background:#dbe8f6}
.btn.full{width:100%}
.btn.sm{padding:8px 13px;font-size:12.5px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:20px;font-family:var(--font-d)}
.tag.derm{background:#fdeede;color:#b06a10}
.tag.dent{background:#e3f0fc;color:#1764a8}
.tag.anti{background:#e8f6ee;color:#1f8a56}
.tag.repr{background:#f3e9fb;color:#7a3fb0}
.tag.supl{background:#eef0f3;color:#4a5868}
.tag.ok{background:var(--verde-bg);color:var(--verde)}
.tag.wait{background:#fdf3e0;color:#b8821f}
.tag.no{background:#fbe9e6;color:var(--vermelho)}
.muted{color:var(--tinta2)}
.divline{height:1px;background:var(--borda);margin:16px 0}

/* ---------- LOGIN ---------- */
.auth-wrap{min-height:calc(100vh - 60px);display:grid;grid-template-columns:1.05fr .95fr}
.auth-art{background:linear-gradient(150deg,var(--azul) 0%,var(--azul-prof) 100%);color:#fff;padding:54px 50px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-art .blob{position:absolute;border-radius:50%;background:rgba(255,255,255,.05)}
.auth-art .b1{width:340px;height:340px;right:-120px;top:-90px}
.auth-art .b2{width:220px;height:220px;left:-80px;bottom:30px;background:rgba(232,163,61,.12)}
.auth-art h2{font-size:34px;font-weight:800;line-height:1.12;letter-spacing:-1px;position:relative;max-width:380px}
.auth-art h2 b{color:var(--ouro)}
.auth-art .sub{position:relative;opacity:.85;margin-top:16px;font-size:15px;max-width:340px}
.auth-feats{position:relative;display:flex;flex-direction:column;gap:14px;margin-top:30px}
.auth-feat{display:flex;gap:12px;align-items:center;font-size:14px}
.auth-feat .ic{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.13);display:grid;place-items:center;flex-shrink:0}
.auth-feat .ic svg{width:18px;height:18px}
.auth-foot{position:relative;font-size:12.5px;opacity:.6}
.auth-form{display:flex;align-items:center;justify-content:center;padding:40px}
.auth-box{width:100%;max-width:360px}
.auth-box h3{font-size:22px;font-weight:800;letter-spacing:-.5px}
.auth-box .lead{color:var(--tinta2);margin:5px 0 22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}
.field input,.field select{width:100%;border:1px solid var(--borda);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px;background:#fbfcfe;transition:.15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--azul);background:#fff;box-shadow:0 0 0 3px rgba(0,78,152,.1)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.auth-tabs{display:flex;gap:6px;background:var(--azul-bg);padding:4px;border-radius:11px;margin-bottom:22px}
.auth-tabs button{flex:1;padding:9px;border-radius:8px;font-weight:700;font-size:13px;color:var(--tinta2);font-family:var(--font-d)}
.auth-tabs button.on{background:#fff;color:var(--azul);box-shadow:var(--sombra)}
@media(max-width:820px){.auth-wrap{grid-template-columns:1fr}.auth-art{display:none}}

/* ---------- NÍVEL / SIGNATURE ---------- */
.level-card{background:linear-gradient(125deg,var(--azul) 0%,var(--azul-prof) 100%);color:#fff;border-radius:18px;padding:24px 26px;position:relative;overflow:hidden;box-shadow:var(--sombra-ft)}
.level-card .glow{position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(232,163,61,.28),transparent 68%);right:-50px;top:-80px}
.level-top{display:flex;align-items:center;gap:18px;position:relative}
.lvl-ring{width:78px;height:78px;flex-shrink:0;position:relative;display:grid;place-items:center}
.lvl-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}
.lvl-ring .num{font-family:var(--font-d);font-weight:800;font-size:27px;line-height:1}
.lvl-ring .lab{font-size:9px;letter-spacing:1px;opacity:.7;text-transform:uppercase}
.level-info .elo{display:inline-flex;align-items:center;gap:6px;background:rgba(232,163,61,.22);color:var(--ouro);font-family:var(--font-d);font-weight:700;font-size:12px;padding:4px 11px;border-radius:20px;margin-bottom:5px}
.level-info h2{font-size:23px;font-weight:800;letter-spacing:-.5px}
.level-info p{opacity:.8;font-size:13px;margin-top:2px}
.level-bar-wrap{margin-top:20px;position:relative}
.level-bar-lbls{display:flex;justify-content:space-between;font-size:12px;margin-bottom:7px;opacity:.85}
.level-bar-lbls b{color:var(--ouro);font-family:var(--font-d)}
.level-bar{height:9px;background:rgba(255,255,255,.16);border-radius:6px;overflow:hidden}
.level-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--ouro),#f6c265);border-radius:6px}

.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.stat{background:var(--surf);border:1px solid var(--borda);border-radius:13px;padding:15px 16px;box-shadow:var(--sombra)}
.stat .k{font-size:12px;color:var(--tinta2);font-weight:600;display:flex;align-items:center;gap:6px}
.stat .v{font-family:var(--font-d);font-weight:800;font-size:24px;letter-spacing:-.5px;margin-top:4px}
.stat .v small{font-size:13px;font-weight:600;color:var(--tinta2)}
.stat .delta{font-size:11.5px;font-weight:700;color:var(--verde);margin-top:2px}
@media(max-width:640px){.stat-row{grid-template-columns:1fr}}

.sec-title{display:flex;align-items:center;justify-content:space-between;margin:26px 0 13px}
.sec-title h3{font-size:16px;font-weight:800;letter-spacing:-.3px}
.sec-title a{color:var(--azul);font-weight:700;font-size:12.5px;cursor:pointer}

/* campanha */
.campaign{display:flex;gap:18px;align-items:center;background:linear-gradient(100deg,#fff6e9,#fdf0db);border:1px solid #f3dcae;border-radius:14px;padding:18px 20px}
.campaign .cic{width:52px;height:52px;border-radius:13px;background:var(--ouro);display:grid;place-items:center;flex-shrink:0;box-shadow:0 6px 16px rgba(232,163,61,.4)}
.campaign h4{font-family:var(--font-d);font-weight:800;font-size:15.5px;color:#9a6512}
.campaign p{font-size:13px;color:#a9762a;margin-top:1px}
.campaign .prog{margin-top:9px;height:7px;background:#f0dcb6;border-radius:5px;overflow:hidden;max-width:340px}
.campaign .prog i{display:block;height:100%;background:var(--ouro);border-radius:5px}
.campaign .cright{margin-left:auto;text-align:right;flex-shrink:0}
.campaign .cright .big{font-family:var(--font-d);font-weight:800;font-size:22px;color:var(--ouro-esc)}
.campaign .cright .lbl{font-size:11px;color:#a9762a;font-weight:600}

/* achievements mini */
.ach-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}
.ach{flex-shrink:0;width:118px;text-align:center;background:var(--surf);border:1px solid var(--borda);border-radius:13px;padding:16px 10px;box-shadow:var(--sombra)}
.ach .medal{width:50px;height:50px;border-radius:50%;margin:0 auto 9px;display:grid;place-items:center;font-size:23px}
.ach.got .medal{background:linear-gradient(135deg,#fbe2b0,#e8a33d)}
.ach.lock .medal{background:#eef1f5;filter:grayscale(1);opacity:.55}
.ach .nm{font-size:12px;font-weight:700;font-family:var(--font-d);line-height:1.2}
.ach .ds{font-size:10.5px;color:var(--tinta2);margin-top:3px}

/* mini ranking */
.rk-row{display:flex;align-items:center;gap:13px;padding:11px 4px;border-bottom:1px solid var(--borda)}
.rk-row:last-child{border-bottom:none}
.rk-pos{width:28px;height:28px;border-radius:8px;background:var(--azul-bg);color:var(--azul);font-family:var(--font-d);font-weight:800;font-size:13px;display:grid;place-items:center;flex-shrink:0}
.rk-pos.g1{background:#fdf0d3;color:#b8821f}.rk-pos.g2{background:#eef1f5;color:#6b7785}.rk-pos.g3{background:#f6e6da;color:#a8642e}
.rk-row .who{flex:1}
.rk-row .who .nm{font-weight:700;font-size:13.5px;font-family:var(--font-d)}
.rk-row .who .ct{font-size:11.5px;color:var(--tinta2)}
.rk-row .pts{font-family:var(--font-d);font-weight:800;font-size:14px;color:var(--azul)}
.rk-row.me{background:var(--azul-bg);margin:0 -8px;padding:11px 12px;border-radius:10px;border:none}

/* receita timeline / steps */
.steps{display:flex;align-items:center;gap:0;margin-bottom:26px}
.step{display:flex;align-items:center;gap:9px;flex:1}
.step .dot{width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--borda);color:var(--tinta2);display:grid;place-items:center;font-weight:700;font-size:12.5px;font-family:var(--font-d);flex-shrink:0;transition:.2s}
.step .nm{font-size:12.5px;font-weight:600;color:var(--tinta2)}
.step .line{flex:1;height:2px;background:var(--borda);margin:0 4px}
.step.on .dot{background:var(--azul);border-color:var(--azul);color:#fff}
.step.on .nm{color:var(--azul);font-weight:700}
.step.done .dot{background:var(--verde);border-color:var(--verde);color:#fff}
.step.done .line,.step.done~.step .line{}
@media(max-width:640px){.step .nm{display:none}}

.upload-zone{border:2px dashed #c3d4e6;border-radius:16px;background:#f7fafd;padding:42px 20px;text-align:center;transition:.18s;cursor:pointer}
.upload-zone:hover{border-color:var(--azul);background:var(--azul-bg)}
.upload-zone .uic{width:62px;height:62px;border-radius:50%;background:var(--azul-bg);display:grid;place-items:center;margin:0 auto 14px}
.upload-zone .uic svg{width:28px;height:28px;color:var(--azul)}
.upload-zone h4{font-size:16px;font-weight:800;font-family:var(--font-d)}
.upload-zone p{color:var(--tinta2);font-size:13px;margin-top:4px}
.up-opts{display:flex;gap:12px;justify-content:center;margin-top:18px}

/* OCR scanning */
.ocr-doc{display:flex;gap:20px;align-items:flex-start}
.ocr-paper{width:230px;flex-shrink:0;background:#fff;border:1px solid var(--borda);border-radius:10px;padding:18px 16px;position:relative;overflow:hidden;box-shadow:var(--sombra)}
.ocr-paper .ph-logo{height:9px;width:80px;background:var(--azul);border-radius:3px;opacity:.85;margin-bottom:14px}
.ocr-paper .ph-line{height:7px;background:#e7edf3;border-radius:3px;margin-bottom:8px}
.ocr-paper .ph-line.hl{background:#fcebcf}
.scan-beam{position:absolute;left:0;right:0;height:38px;background:linear-gradient(180deg,transparent,rgba(0,78,152,.18),transparent);border-top:2px solid var(--azul);animation:scan 1.7s ease-in-out infinite}
@keyframes scan{0%{top:-10%}100%{top:100%}}
.ocr-status{flex:1}
.ocr-status .working{display:flex;align-items:center;gap:11px;font-weight:700;color:var(--azul);font-family:var(--font-d);font-size:15px}
.spin{width:20px;height:20px;border:2.5px solid var(--azul-bg);border-top-color:var(--azul);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

.prod-found{display:flex;align-items:center;gap:13px;border:1px solid var(--borda);border-radius:12px;padding:13px 15px;margin-bottom:11px;transition:.15s}
.prod-found:hover{border-color:var(--azul-claro)}
.prod-found .pic{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-weight:800;color:#fff;font-family:var(--font-d);font-size:15px;flex-shrink:0}
.prod-found .pinfo{flex:1}
.prod-found .pinfo .nm{font-weight:700;font-family:var(--font-d);font-size:14.5px}
.prod-found .pinfo .meta{font-size:12px;color:var(--tinta2);margin-top:2px}
.prod-found .conf{font-size:11px;font-weight:700;color:var(--verde);background:var(--verde-bg);padding:3px 9px;border-radius:20px}
.prod-found .ppts{font-family:var(--font-d);font-weight:800;color:var(--ouro-esc);font-size:16px;text-align:right}
.prod-found .ppts small{display:block;font-size:10px;color:var(--tinta2);font-weight:600}
.rx-rm{width:26px;height:26px;border-radius:7px;background:#fbe9e6;color:var(--vermelho);font-weight:700;font-size:13px;flex-shrink:0;display:grid;place-items:center;transition:.13s}
.rx-rm:hover{background:#f6d8d3}
.rx-add{display:flex;gap:8px;align-items:center;margin:14px 0 2px}
.rx-add select{flex:1;border:1px solid var(--borda);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13px;background:#fbfcfe}

.review-pts{background:linear-gradient(120deg,var(--azul),var(--azul-prof));color:#fff;border-radius:14px;padding:20px 22px;display:flex;align-items:center;gap:16px}
.review-pts .rcoin{width:54px;height:54px;border-radius:50%;background:var(--ouro);display:grid;place-items:center;font-size:26px;flex-shrink:0;box-shadow:0 6px 18px rgba(232,163,61,.45)}
.review-pts .rt h4{font-size:13px;opacity:.85;font-weight:600}
.review-pts .rt .v{font-family:var(--font-d);font-weight:800;font-size:30px;letter-spacing:-1px}
.review-pts .rt .v small{font-size:14px;opacity:.8}

/* tabela receitas */
.rx-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--borda)}
.rx-item:last-child{border:none}
.rx-item .rpic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;font-family:var(--font-d);font-weight:800;flex-shrink:0;font-size:14px}
.rx-item .rinfo{flex:1;min-width:0}
.rx-item .rinfo .nm{font-weight:700;font-family:var(--font-d);font-size:14px}
.rx-item .rinfo .meta{font-size:12px;color:var(--tinta2);margin-top:2px}
.rx-item .rpts{font-family:var(--font-d);font-weight:800;color:var(--azul);font-size:14px;text-align:right;flex-shrink:0}

/* mercadinho */
.shop-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:8px 15px;border-radius:20px;border:1px solid var(--borda);background:#fff;font-weight:600;font-size:12.5px;color:var(--tinta2);transition:.13s}
.chip:hover{border-color:var(--azul-claro)}
.chip.on{background:var(--azul);color:#fff;border-color:var(--azul)}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.shop-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.shop-grid{grid-template-columns:1fr}}
.prize{background:var(--surf);border:1px solid var(--borda);border-radius:15px;overflow:hidden;box-shadow:var(--sombra);transition:.16s;display:flex;flex-direction:column}
.prize:hover{transform:translateY(-3px);box-shadow:var(--sombra-ft)}
.prize .img{height:128px;display:grid;place-items:center;font-size:52px;position:relative}
.prize .img .ribbon{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.34);color:#fff;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;backdrop-filter:blur(3px)}
.prize .pbody{padding:14px 15px;display:flex;flex-direction:column;flex:1}
.prize .pbody h4{font-size:14.5px;font-weight:800;font-family:var(--font-d);line-height:1.2}
.prize .pbody .pd{font-size:12px;color:var(--tinta2);margin-top:3px;flex:1}
.prize .cost{display:flex;align-items:center;gap:6px;font-family:var(--font-d);font-weight:800;font-size:17px;color:var(--azul);margin:12px 0 11px}
.prize .cost .c{width:18px;height:18px;border-radius:50%;background:var(--ouro);display:grid;place-items:center;font-size:10px;color:#fff}
.prize .cost.cant{color:var(--tinta2)}
.prize-btn{padding:10px;border-radius:10px;font-weight:700;font-size:13px;font-family:var(--font-d);width:100%;transition:.14s}
.prize-btn.can{background:var(--azul);color:#fff}.prize-btn.can:hover{background:var(--azul-esc)}
.prize-btn.no{background:#eef1f5;color:var(--tinta2);cursor:not-allowed}
.prize-btn.no small{display:block;font-size:10px;font-weight:600}

/* conquistas grid */
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px}
.acard{background:var(--surf);border:1px solid var(--borda);border-radius:14px;padding:18px 16px;text-align:center;box-shadow:var(--sombra);position:relative}
.acard .medal{width:58px;height:58px;border-radius:50%;margin:0 auto 11px;display:grid;place-items:center;font-size:27px}
.acard.got .medal{background:linear-gradient(135deg,#fbe2b0,#e8a33d);box-shadow:0 6px 16px rgba(232,163,61,.35)}
.acard.lock .medal{background:#eef1f5;filter:grayscale(1);opacity:.5}
.acard h4{font-size:13.5px;font-weight:800;font-family:var(--font-d)}
.acard p{font-size:11.5px;color:var(--tinta2);margin-top:4px;min-height:30px}
.acard .ck{position:absolute;top:11px;right:11px;width:20px;height:20px;border-radius:50%;background:var(--verde);display:grid;place-items:center}
.acard.lock .pbar{height:5px;background:#eef1f5;border-radius:4px;margin-top:10px;overflow:hidden}
.acard.lock .pbar i{display:block;height:100%;background:var(--azul-claro)}
.acard.lock .pnum{font-size:10.5px;color:var(--tinta2);margin-top:5px;font-weight:600}

/* trilha de níveis */
.track{display:flex;gap:0;overflow-x:auto;padding:10px 4px 14px}
.track-node{flex-shrink:0;width:130px;text-align:center;position:relative}
.track-node .conn{position:absolute;top:26px;left:50%;width:100%;height:3px;background:var(--borda);z-index:0}
.track-node.done .conn{background:var(--ouro)}
.track-node:last-child .conn{display:none}
.track-node .badge-c{width:54px;height:54px;border-radius:50%;margin:0 auto 9px;display:grid;place-items:center;font-family:var(--font-d);font-weight:800;font-size:18px;position:relative;z-index:1;border:3px solid var(--bg)}
.track-node.done .badge-c{background:linear-gradient(135deg,#fbe2b0,#e8a33d);color:#fff}
.track-node.cur .badge-c{background:var(--azul);color:#fff;box-shadow:0 0 0 4px var(--azul-bg)}
.track-node.fut .badge-c{background:#eef1f5;color:var(--tinta2)}
.track-node .tn{font-size:12px;font-weight:700;font-family:var(--font-d)}
.track-node .tp{font-size:10.5px;color:var(--tinta2)}

/* ranking page */
.podium{display:flex;align-items:flex-end;justify-content:center;gap:14px;margin:8px 0 26px}
.pod-col{text-align:center;flex:1;max-width:150px}
.pod-col .av{width:54px;height:54px;border-radius:50%;margin:0 auto 8px;display:grid;place-items:center;font-family:var(--font-d);font-weight:800;color:#fff;font-size:18px;border:3px solid #fff;box-shadow:var(--sombra)}
.pod-col .ct{font-size:12px;font-weight:700;font-family:var(--font-d)}
.pod-col .pt{font-size:11.5px;color:var(--azul);font-weight:700}
.pod-col .stand{border-radius:10px 10px 0 0;margin-top:9px;display:grid;place-items:center;color:#fff;font-family:var(--font-d);font-weight:800;font-size:22px}
.pod-col.first .av{background:linear-gradient(135deg,#f6c75e,#d99318);width:64px;height:64px;font-size:21px}
.pod-col.first .stand{height:90px;background:linear-gradient(180deg,#e8a33d,#c9852a)}
.pod-col.second .av{background:linear-gradient(135deg,#bcc6d1,#8a97a6)}
.pod-col.second .stand{height:66px;background:linear-gradient(180deg,#9aa6b3,#73818f)}
.pod-col.third .av{background:linear-gradient(135deg,#d8a578,#b07444)}
.pod-col.third .stand{height:50px;background:linear-gradient(180deg,#b9784a,#9a6038)}

/* admin */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:860px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--surf);border:1px solid var(--borda);border-radius:13px;padding:16px 17px;box-shadow:var(--sombra)}
.kpi .ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:11px}
.kpi .ic svg{width:19px;height:19px}
.kpi .k{font-size:12px;color:var(--tinta2);font-weight:600}
.kpi .v{font-family:var(--font-d);font-weight:800;font-size:25px;letter-spacing:-.5px;margin-top:2px}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--tinta2);font-weight:700;padding:11px 13px;border-bottom:1px solid var(--borda)}
.tbl td{padding:12px 13px;border-bottom:1px solid var(--borda)}
.tbl tr:last-child td{border:none}
.tbl tr:hover td{background:#fafcfe}
.import-zone{border:2px dashed #c3d4e6;border-radius:14px;background:#f7fafd;padding:30px 20px;text-align:center}
.mini-act{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;padding:6px 11px;border-radius:8px;font-family:var(--font-d)}
.mini-act.ok{background:var(--verde-bg);color:var(--verde)}.mini-act.ok:hover{background:#d3eede}
.mini-act.no{background:#fbe9e6;color:var(--vermelho)}.mini-act.no:hover{background:#f6d8d3}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(10,28,48,.55);z-index:90;display:grid;place-items:center;padding:20px;backdrop-filter:blur(2px)}
.modal{background:#fff;border-radius:18px;max-width:400px;width:100%;padding:30px 28px;text-align:center;box-shadow:var(--sombra-ft);animation:pop .2s ease}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal .mic{width:66px;height:66px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;font-size:32px}
.modal h3{font-size:20px;font-weight:800;font-family:var(--font-d);letter-spacing:-.4px}
.modal p{color:var(--tinta2);margin:7px 0 22px;font-size:13.5px}
.toast{position:fixed;bottom:max(24px,calc(env(safe-area-inset-bottom,0px) + 10px));left:50%;transform:translateX(-50%) translateY(80px);background:var(--azul-prof);color:#fff;padding:13px 22px;border-radius:12px;font-weight:600;font-size:13.5px;z-index:95;box-shadow:var(--sombra-ft);transition:.3s;display:flex;align-items:center;gap:9px}
.toast.show{transform:translateX(-50%) translateY(0)}

.proto-note{background:#fff8ec;border:1px solid #f1ddb4;border-radius:11px;padding:12px 15px;font-size:12.5px;color:#8a6418;display:flex;gap:9px;align-items:flex-start;margin-bottom:20px}
.proto-note svg{width:17px;height:17px;flex-shrink:0;margin-top:1px}

/* ---- validação de receita (admin) ---- */
.aprov-ctrl{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin-bottom:16px}
.aprov-ctrl .grp-c{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.aprov-ctrl .lbl{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tinta2)}
.qbadge{display:inline-flex;align-items:center;gap:5px;background:var(--azul-bg);color:var(--azul);font-family:var(--font-d);font-weight:800;font-size:12.5px;padding:4px 10px;border-radius:8px;white-space:nowrap}
.qbadge.multi{background:#fdf3e0;color:#b8821f}
.rx-thumb{width:42px;height:54px;border-radius:7px;overflow:hidden;border:1px solid var(--borda);flex-shrink:0;cursor:pointer;background:#fff;position:relative;transition:.14s}
.rx-thumb:hover{border-color:var(--azul);box-shadow:0 3px 10px rgba(0,40,80,.14)}
.rx-thumb svg{width:100%;height:100%;display:block}
.rx-thumb .zoom{position:absolute;inset:0;background:rgba(0,78,152,.0);display:grid;place-items:center;transition:.14s}
.rx-thumb:hover .zoom{background:rgba(0,78,152,.32)}
.rx-thumb .zoom svg{width:16px;height:16px;color:#fff;opacity:0}
.rx-thumb:hover .zoom svg{opacity:1}

.modal.lg{max-width:780px;width:100%;text-align:left;padding:0;overflow:hidden;max-height:92vh;display:flex;flex-direction:column}
.val-head{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--borda)}
.val-head h3{font-size:18px;font-weight:800}
.val-head .sub{font-size:12.5px;color:var(--tinta2);margin-top:2px}
.val-head .x{font-size:20px;color:var(--tinta2);width:32px;height:32px;border-radius:8px}
.val-head .x:hover{background:var(--bg)}
.val-body{display:grid;grid-template-columns:288px 1fr;flex:1;min-height:0}
.val-photo{background:#eef2f7;padding:16px;border-right:1px solid var(--borda);overflow:auto}
.val-photo .ttl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tinta2);margin-bottom:9px}
.val-photo .doc{border-radius:8px;overflow:hidden;box-shadow:var(--sombra);background:#fff}
.val-list{padding:18px 22px;overflow:auto}
.val-list .meta-vet{font-size:12.5px;color:var(--tinta2);margin-bottom:14px;line-height:1.7}
.val-list .meta-vet b{color:var(--tinta)}
.vp-row{border:1px solid var(--borda);border-radius:11px;padding:12px 13px;margin-bottom:10px;transition:.14s}
.vp-row.off{opacity:.5;background:#fafbfc}
.vp-top{display:flex;align-items:center;gap:11px}
.vp-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--borda);flex-shrink:0;display:grid;place-items:center;cursor:pointer;transition:.13s}
.vp-check.on{background:var(--verde);border-color:var(--verde)}
.vp-check svg{width:13px;height:13px;color:#fff;opacity:0}
.vp-check.on svg{opacity:1}
.vp-pic{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:#fff;font-family:var(--font-d);font-weight:800;font-size:12px;flex-shrink:0}
.vp-info{flex:1;min-width:0}
.vp-info .nm{font-weight:700;font-family:var(--font-d);font-size:14px}
.vp-info .cf{font-size:11px;font-weight:700}
.vp-pts{font-family:var(--font-d);font-weight:800;color:var(--ouro-esc);font-size:15px}
.vp-edit{margin-top:10px;display:flex;gap:8px;align-items:center}
.vp-edit select{flex:1;border:1px solid var(--borda);border-radius:8px;padding:7px 9px;font-family:inherit;font-size:12.5px;background:#fbfcfe}
.vp-edit .hint{font-size:11px;color:var(--tinta2)}
.val-total{display:flex;align-items:center;justify-content:space-between;background:var(--azul-bg);border-radius:11px;padding:13px 15px;margin-top:6px}
.val-total .t{font-size:12.5px;font-weight:600;color:var(--azul)}
.val-total .v{font-family:var(--font-d);font-weight:800;font-size:22px;color:var(--azul)}
.val-foot{display:flex;gap:10px;padding:15px 22px;border-top:1px solid var(--borda)}
@media(max-width:680px){
  .val-body{grid-template-columns:1fr}
  .val-photo{border-right:none;border-bottom:1px solid var(--borda);max-height:300px}
}

/* ---- personalização (white-label) ---- */
.cfg-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.cfg-grid{grid-template-columns:1fr}}
.cfg-card{background:var(--surf);border:1px solid var(--borda);border-radius:14px;padding:18px 20px;box-shadow:var(--sombra)}
.cfg-card .ch{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.cfg-card .ch .ci{width:32px;height:32px;border-radius:9px;background:var(--azul-bg);color:var(--azul);display:grid;place-items:center}
.cfg-card .ch .ci svg{width:17px;height:17px}
.cfg-card .ch h3{font-size:14.5px;font-weight:800}
.cfg-card .ch p{font-size:11.5px;color:var(--tinta2)}
.cfg-row{margin-bottom:13px}
.cfg-row:last-child{margin-bottom:0}
.cfg-row label{display:block;font-size:12px;font-weight:600;margin-bottom:6px}
.cfg-row input[type=text],.cfg-row select{width:100%;border:1px solid var(--borda);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13.5px;background:#fbfcfe}
.cfg-row input:focus,.cfg-row select:focus{outline:none;border-color:var(--azul);box-shadow:0 0 0 3px rgba(0,78,152,.1)}
.color-field{display:flex;align-items:center;gap:11px}
.color-field input[type=color]{width:46px;height:38px;border:1px solid var(--borda);border-radius:9px;padding:2px;background:#fff;cursor:pointer;flex-shrink:0}
.color-field .hex{font-family:var(--font-d);font-weight:700;font-size:13px;color:var(--tinta2)}
.theme-presets{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:4px}
.tp{border:2px solid var(--borda);border-radius:11px;padding:8px 9px 7px;cursor:pointer;transition:.14s;background:#fff;text-align:center;min-width:64px}
.tp.on{border-color:var(--azul)}
.tp .swatch{display:flex;gap:3px;justify-content:center;margin-bottom:5px}
.tp .swatch i{width:14px;height:14px;border-radius:4px}
.tp .tn{font-size:10.5px;font-weight:700;font-family:var(--font-d)}
.lbl-pair{display:grid;grid-template-columns:1fr 1fr;gap:9px 14px}
@media(max-width:520px){.lbl-pair{grid-template-columns:1fr}}
.lbl-pair .from{font-size:11px;color:var(--tinta2);align-self:center}
.cfg-preview-pill{display:inline-flex;align-items:center;gap:7px;background:var(--azul);color:#fff;border-radius:20px;padding:6px 13px;font-weight:700;font-family:var(--font-d);font-size:13px}
.cfg-preview-pill .vb{background:#fff;color:var(--azul);border-radius:5px;padding:1px 7px;font-size:12px}

/* ---- relatórios ---- */
.rel-filters{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:760px){.rel-filters{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.rel-filters{grid-template-columns:1fr}}
.rel-filters label{display:block;font-size:11.5px;font-weight:600;margin-bottom:5px;color:var(--tinta2)}
.rel-filters select{width:100%;border:1px solid var(--borda);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13px;background:#fbfcfe}
.rel-filters select:focus{outline:none;border-color:var(--azul);box-shadow:0 0 0 3px rgba(0,78,152,.1)}
.bk-row{margin-bottom:11px}
.bk-row .bk-top{display:flex;justify-content:space-between;font-size:12.5px;font-weight:600;margin-bottom:5px}
.bk-row .bk-top .v{color:var(--tinta2);font-family:var(--font-d)}
.bk-bar{height:8px;background:#eef1f5;border-radius:5px;overflow:hidden}
.bk-bar i{display:block;height:100%;border-radius:5px}
.eq-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--tinta2);margin-bottom:8px}
.eq-person{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--borda);border-radius:10px;margin-bottom:7px}
.eq-person .ava{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;font-family:var(--font-d);flex-shrink:0}
.eq-person .ava.verde{background:var(--verde)}
.eq-person .ava.roxo{background:#7a3fb0}
/* ---------- ajustes do sistema real ---------- */
.flash{position:fixed;top:74px;left:50%;transform:translateX(-50%);background:var(--azul-prof);color:#fff;padding:11px 18px;border-radius:10px;font-size:13.5px;font-weight:600;z-index:60;box-shadow:0 8px 30px rgba(0,40,80,.25);max-width:92%;text-align:center}
.demo-badge{display:inline-flex;align-items:center;gap:6px;background:#fff3da;color:#8a5d12;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;margin-left:8px}
.em-breve{display:grid;place-items:center;min-height:50vh;text-align:center}
.em-breve .ic{font-size:46px;margin-bottom:10px}
.em-breve h2{font-size:22px;font-weight:800}
.em-breve p{color:var(--tinta2);margin-top:6px;max-width:420px}
.upload-zone{display:block}
.dup-aviso{background:#fdf3e0;color:#8a5d12;border:1px solid #f1ddb4;border-radius:12px;padding:12px 16px;font-size:13.5px;margin-bottom:18px}
.dup-aviso a{color:#8a5d12;font-weight:700;text-decoration:underline}
.dup-aviso-outro-vet{background:#fbe9e6;color:#8a2218;border-color:#f5c0b8}
.dup-aviso-outro-vet a{color:#8a2218}
/* botão de modo demo na topbar */
.demo-toggle-btn{font-size:12px;font-weight:700;padding:6px 13px;border-radius:20px;background:rgba(255,255,255,.14);color:rgba(255,255,255,.85);transition:.15s;font-family:var(--font-d);white-space:nowrap;cursor:pointer;border:none}
.demo-toggle-btn:hover{background:rgba(255,255,255,.25)}
.demo-toggle-on{background:#fff3da;color:#8a5d12}
.demo-toggle-on:hover{background:#ffe8b0}
