/* ═══════════════ VARIÁVEIS ═══════════════ */
:root{
  --p:#7c3aed;--pl:#a78bfa;--pd:#5b21b6;--pbg:#ede9fe;--pxl:#f5f3ff;
  --g:#059669;--gbg:#d1fae5;--r:#dc2626;--rbg:#fee2e2;--a:#d97706;--abg:#fef3c7;
  --g50:#f9fafb;--g100:#f3f4f6;--g200:#e5e7eb;--g300:#d1d5db;
  --g400:#9ca3af;--g500:#6b7280;--g600:#4b5563;--g700:#374151;
  --g800:#1f2937;--g900:#111827;
  --sw:220px;--font:'Sora',sans-serif;--mono:'JetBrains Mono',monospace;
  --r8:8px;--r12:12px;
  --sh:0 1px 3px rgba(0,0,0,.08);--shm:0 4px 16px rgba(0,0,0,.1);
  --shp:0 4px 20px rgba(124,58,237,.3);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:var(--font);font-size:14px;color:var(--g800);background:var(--g50)}
a{text-decoration:none;color:inherit}
button{font-family:var(--font);cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:var(--font);outline:none}

/* ═══════════════ LOGIN ═══════════════ */
#login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1e1b4b 0%,#4c1d95 50%,#2e1065 100%)}
.login-wrap{width:100%;padding:1rem}
.login-card{background:rgba(255,255,255,.97);border-radius:20px;padding:2.5rem 2rem;
  width:100%;max-width:400px;margin:0 auto;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.brand{font-size:22px;font-weight:700;color:var(--g900)}
.brand span{color:var(--p)}
.brand-sub{font-size:12px;color:var(--g500);margin-top:3px}
.login-titulo{font-size:17px;font-weight:600;margin:1.5rem 0 1.25rem;color:var(--g800)}
.err-box{background:var(--rbg);color:var(--r);font-size:12px;padding:8px 12px;
  border-radius:var(--r8);margin-bottom:.75rem}
.login-dica{margin-top:1rem;font-size:12px;color:var(--g400);text-align:center;line-height:1.7}
.login-dica code{background:var(--g100);padding:2px 6px;border-radius:4px;font-family:var(--mono);font-size:11px;color:var(--g600)}

/* ═══════════════ FORMULÁRIOS ═══════════════ */
.fg{margin-bottom:.9rem}
.fg label{display:block;font-size:12px;font-weight:500;color:var(--g600);margin-bottom:5px}
.fg input,.fg select{width:100%;padding:10px 14px;border:1.5px solid var(--g200);
  border-radius:var(--r8);font-size:14px;color:var(--g800);background:var(--g50);transition:border-color .2s}
.fg input:focus,.fg select:focus{border-color:var(--p);background:#fff}
.btn-p{width:100%;padding:11px;background:var(--p);color:#fff;border-radius:var(--r8);
  font-size:14px;font-weight:600;transition:background .2s;box-shadow:var(--shp)}
.btn-p:hover{background:var(--pd)}
.btn-p:disabled{opacity:.6;cursor:not-allowed}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}

/* ═══════════════ APP LAYOUT ═══════════════ */
#app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sw);background:#fff;border-right:1px solid var(--g200);
  display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sb-logo{padding:1.25rem;border-bottom:1px solid var(--g100)}
.sb-bal{padding:.75rem 1.25rem;border-bottom:1px solid var(--g100)}
.lbl{font-size:10px;color:var(--g400);font-weight:500;text-transform:uppercase;letter-spacing:.06em}
.val{font-size:13px;font-weight:600;color:var(--g800);margin:2px 0}
.bal-bar{height:4px;background:var(--g100);border-radius:2px;overflow:hidden;margin-top:6px}
.bal-fill{height:100%;background:var(--p);border-radius:2px;width:0%;transition:width .5s}
.bal-pct{font-size:10px;color:var(--g400);margin-top:3px}
.sb-sec{padding:.75rem 1.25rem .25rem;font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.08em}
.nav-item{display:flex;align-items:center;gap:10px;padding:.6rem 1.25rem;font-size:13px;font-weight:500;color:var(--g600);transition:all .15s;margin:1px 8px;border-radius:var(--r8)}
.nav-item:hover{background:var(--pxl);color:var(--p)}
.nav-item.ativo{background:var(--pbg);color:var(--p);font-weight:600}
.nav-item svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.sb-footer{margin-top:auto;padding:1rem 1.25rem;border-top:1px solid var(--g100);display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--pbg);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--p)}
.sb-nome{font-size:13px;font-weight:500;color:var(--g700)}
.sb-role{font-size:11px;color:var(--g400)}
.btn-sair{margin-left:auto;color:var(--g400);padding:4px;transition:color .15s}
.btn-sair:hover{color:var(--r)}
.btn-sair svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--g200);padding:.875rem 2rem;
  display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.topbar-titulo{font-size:16px;font-weight:600;color:var(--g900)}
.filtro{padding:6px 12px;border:1.5px solid var(--g200);border-radius:var(--r8);font-size:12px;color:var(--g700);background:#fff;cursor:pointer}
.pg-content{padding:1.5rem 2rem;flex:1}

/* ═══════════════ COMPONENTES ═══════════════ */
.banner{background:linear-gradient(120deg,#4c1d95,#7c3aed,#6d28d9);border-radius:var(--r12);padding:1.75rem 2rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden}
.banner::before{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.07)}
.banner h2{font-size:20px;font-weight:700;color:#fff}
.banner p{font-size:12px;color:rgba(255,255,255,.65);margin-top:3px}
.banner-badge{background:rgba(255,255,255,.15);color:#fff;font-size:11px;padding:4px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.25)}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.mc{background:#fff;border:1px solid var(--g200);border-radius:var(--r12);padding:1.25rem;display:flex;align-items:flex-start;justify-content:space-between;box-shadow:var(--sh);transition:box-shadow .2s}
.mc:hover{box-shadow:var(--shm)}
.mc.feat{border-color:var(--pl);background:var(--pxl)}
.ml{font-size:10px;color:var(--g400);font-weight:500;text-transform:uppercase;letter-spacing:.05em}
.mv{font-size:20px;font-weight:700;color:var(--g900);margin-top:6px;line-height:1.2}
.mc.feat .mv{color:var(--pd);font-size:17px}
.ms{font-size:11px;color:var(--a);margin-top:4px}
.mic{width:38px;height:38px;border-radius:50%;background:var(--p);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mic svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.grid2{display:grid;grid-template-columns:1fr 240px;gap:1rem}
.card{background:#fff;border:1px solid var(--g200);border-radius:var(--r12);box-shadow:var(--sh)}
.ch{padding:1rem 1.25rem;border-bottom:1px solid var(--g100);font-size:13px;font-weight:600;color:var(--g700)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{padding:.55rem 1.25rem;font-size:11px;font-weight:500;color:var(--g400);text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--g100)}
.tbl td{padding:.7rem 1.25rem;font-size:13px;color:var(--g700);border-bottom:1px solid var(--g50)}
.tbl tr:last-child td{border-bottom:none}
.pm{display:flex;align-items:center;gap:9px}
.pd-dot{width:7px;height:7px;border-radius:50%}
.si{padding:.8rem 1.25rem;border-bottom:1px solid var(--g50);display:flex;justify-content:space-between;align-items:center}
.si:last-child{border-bottom:none}
.si-lbl{font-size:12px;color:var(--g500)}
.si-val{font-size:17px;font-weight:700;color:var(--p)}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}
.b-ok{background:var(--gbg);color:var(--g)}
.b-pu{background:var(--pbg);color:var(--p)}
.b-warn{background:var(--abg);color:var(--a)}

/* PRODUTOS */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.ph h2{font-size:17px;font-weight:600;color:var(--g900)}
.btn-add{display:flex;align-items:center;gap:7px;padding:9px 16px;background:var(--p);color:#fff;border-radius:var(--r8);font-size:13px;font-weight:600;box-shadow:var(--shp);transition:background .2s}
.btn-add:hover{background:var(--pd)}
.btn-add svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2.5}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.pcard{background:#fff;border:1px solid var(--g200);border-radius:var(--r12);overflow:hidden;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s}
.pcard:hover{box-shadow:var(--shm);transform:translateY(-2px)}
.pt-thumb{height:88px;background:linear-gradient(135deg,#4c1d95,#7c3aed);display:flex;align-items:center;justify-content:center}
.pt-thumb svg{width:34px;height:34px;stroke:rgba(255,255,255,.4);fill:none;stroke-width:1.5}
.pb{padding:.875rem 1.25rem}
.pn{font-size:14px;font-weight:600;color:var(--g900);margin-bottom:3px}
.pdesc{font-size:12px;color:var(--g500);margin-bottom:.5rem;line-height:1.5}
.pp{font-size:17px;font-weight:700;color:var(--p);margin-bottom:.6rem}
.plb{display:flex;align-items:center;gap:7px;background:var(--g50);border:1px solid var(--g200);border-radius:var(--r8);padding:5px 9px;font-size:11px;font-family:var(--mono);color:var(--g500);margin-bottom:.6rem;overflow:hidden}
.plb span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-btn{background:none;padding:2px;color:var(--g400);transition:color .15s;flex-shrink:0;border:none;cursor:pointer}
.copy-btn:hover{color:var(--p)}
.pa{display:flex;gap:.5rem}
.btn-gw{flex:1;padding:7px 10px;background:var(--p);color:#fff;border-radius:var(--r8);font-size:12px;font-weight:600;text-align:center;transition:background .2s;cursor:pointer;border:none}
.btn-gw:hover{background:var(--pd)}
.btn-ol{padding:7px 10px;background:#fff;color:var(--g600);border:1px solid var(--g200);border-radius:var(--r8);font-size:12px;font-weight:500;transition:all .15s;cursor:pointer;text-align:center}
.btn-ol:hover{border-color:var(--p);color:var(--p)}
.empty{text-align:center;padding:3rem 2rem;color:var(--g400)}
.empty svg{width:44px;height:44px;margin:0 auto 1rem;display:block;stroke:currentColor;fill:none;stroke-width:1.5;opacity:.25}

/* TABELAS */
.tt{width:100%;border-collapse:collapse}
.tt th{padding:.65rem 1.25rem;font-size:11px;font-weight:500;color:var(--g400);text-align:left;text-transform:uppercase;letter-spacing:.05em;background:var(--g50)}
.tt td{padding:.8rem 1.25rem;font-size:13px;border-bottom:1px solid var(--g50)}

/* SEGURANÇA */
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.acard{background:#fff;border:1px solid var(--g200);border-radius:var(--r12);padding:1rem 1.25rem;box-shadow:var(--sh)}
.al{font-size:10px;color:var(--g400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}
.av{font-size:26px;font-weight:700}
.ad{font-size:12px;color:var(--g500);margin-top:3px}
.ai{display:flex;align-items:flex-start;gap:11px;padding:.8rem 1.25rem;border-bottom:1px solid var(--g50)}
.ai:last-child{border-bottom:none}
.adot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}
.dr{background:var(--r)}.da{background:var(--a)}.dg{background:var(--g)}.db{background:#3b82f6}
.at{font-size:13px;color:var(--g700);line-height:1.5}
.atm{font-size:11px;color:var(--g400);margin-top:2px}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.overlay.aberto{display:flex}
.modal{background:#fff;border-radius:16px;padding:1.75rem;width:100%;max-width:460px;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:slideUp .3s ease;max-height:90vh;overflow-y:auto;padding-bottom:2rem}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.mh h3{font-size:15px;font-weight:600;color:var(--g900)}
.mclose{background:none;color:var(--g400);font-size:20px;padding:4px;line-height:1;cursor:pointer}

/* LIXEIRAS */
.btn-lixeira{background:none;border:none;cursor:pointer;color:var(--g300);font-size:15px;padding:3px 6px;border-radius:6px;transition:all .2s}
.btn-lixeira:hover{color:var(--r);background:var(--rbg)}
.btn-lixeira-geral{display:flex;align-items:center;gap:5px;padding:5px 12px;background:var(--rbg);color:var(--r);border:1.5px solid #fca5a5;border-radius:var(--r8);font-size:11px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s}
.btn-lixeira-geral:hover{background:var(--r);color:#fff}

/* MOBILE NAV */
.mobile-nav{display:none;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--g200);z-index:500;padding:.4rem 0;box-shadow:0 -4px 16px rgba(0,0,0,.08)}
.mob-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;padding:.3rem .5rem;color:var(--g400);font-family:var(--font);font-size:10px;font-weight:500;min-width:52px;transition:color .15s;text-decoration:none}
.mob-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.mob-btn.ativo{color:var(--p)}
.mob-btn.ativo svg{stroke:var(--p)}

/* TOAST */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--g900);color:#fff;padding:.75rem 1.25rem;border-radius:var(--r8);font-size:13px;z-index:3000;display:none;box-shadow:var(--shm);max-width:320px}

/* RELATORIOS checkboxes */
.chk-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--g700);background:var(--g50);border:1.5px solid var(--g200);border-radius:8px;padding:8px 14px;transition:all .2s;user-select:none}
.chk-label input{width:16px;height:16px;accent-color:var(--p);cursor:pointer}
.chk-label:has(input:checked){background:var(--pbg);border-color:var(--pl);color:var(--p)}

/* CAP BOX */
.cap-box{background:var(--g50);border:1px solid var(--g200);border-radius:var(--r8);padding:1rem;text-align:left;margin:1rem 0}
.cap-titulo{font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}
.cap-row{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-bottom:1px solid var(--g200)}
.cap-row:last-child{border-bottom:none}
.cap-k{color:var(--g500)}
.cap-v{font-weight:500;color:var(--g800);font-family:var(--mono);font-size:11px}

/* ═══════════════ RESPONSIVO ═══════════════ */
@media(max-width:768px){
  .sidebar{display:none!important}
  .mobile-nav{display:flex!important}
  #app{flex-direction:column}
  .main{min-height:0}
  .topbar{padding:.65rem 1rem;position:sticky;top:0}
  .pg-content{padding:.875rem 1rem 5.5rem}
  .metrics{grid-template-columns:1fr 1fr;gap:.625rem;margin-bottom:1rem}
  .mc{padding:.875rem}
  .mv{font-size:16px}
  .mc.feat .mv{font-size:14px}
  .banner{padding:1.25rem 1rem;flex-direction:column;gap:.5rem;text-align:center;margin-bottom:1rem}
  .banner h2{font-size:16px}
  .grid2{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr 1fr;gap:.625rem}
  .pgrid{grid-template-columns:1fr}
  .ph{flex-wrap:wrap;gap:.5rem}
  .card{overflow-x:auto}
  .overlay{align-items:flex-end;padding:0}
  .modal{margin:0;border-radius:16px 16px 0 0;max-height:88vh;overflow-y:auto;padding:1.25rem}
  .fr{grid-template-columns:1fr}
  #pg-relatorios > div:last-child{grid-template-columns:1fr!important}
}
@media(max-width:420px){
  .metrics{grid-template-columns:1fr}
  .sgrid{grid-template-columns:1fr}
}

/* ══ PRODUTOS ══ */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.ph h2{font-size:18px;font-weight:700;color:var(--g900)}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.prod-card{background:#fff;border:1.5px solid var(--g200);border-radius:14px;overflow:hidden;box-shadow:var(--sh);transition:box-shadow .2s}
.prod-card:hover{box-shadow:var(--shm)}
.prod-img{height:160px;background:var(--g100);display:flex;align-items:center;justify-content:center;overflow:hidden}
.prod-img img{width:100%;height:100%;object-fit:cover}
.prod-body{padding:1rem}
.prod-nome{font-size:14px;font-weight:700;color:var(--g900)}
.prod-desc{font-size:12px;color:var(--g500);margin:.25rem 0 .5rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.prod-preco{font-size:18px;font-weight:700;color:var(--p);margin-bottom:.75rem}
.plb{display:flex;align-items:center;background:var(--g50);border:1px solid var(--g200);border-radius:6px;padding:4px 8px;gap:4px}
.plb span{font-size:10px;font-family:monospace;color:var(--g500);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-btn{background:none;border:none;cursor:pointer;font-size:12px;padding:2px;flex-shrink:0}
.empty-state{text-align:center;padding:3rem;color:var(--g400);background:#fff;border:1.5px dashed var(--g200);border-radius:12px}

/* ══ RESPONSIVO EXTRA ══ */
@media(max-width:768px){
  .prod-grid{grid-template-columns:1fr}
  .prod-card .plb span{font-size:9px}
  .topbar-titulo{font-size:14px}
}

/* ══ VER.PHP RESPONSIVO ══ */
@media(max-width:520px){
  #apres-body > div{padding:1rem .75rem}
  #apres-body h1{font-size:18px}
}
