
/* AgroRodones V4.2 HOTFIX VISUAL PDV - somente layout, app.js preservado */
:root{
  --dark:#111827;--dark2:#0b1220;--ribbon:#eef2f7;--bg:#eef3ef;--card:#ffffff;--text:#071422;--muted:#64748b;--line:#d9e2dd;
  --green:#16a34a;--green2:#15803d;--orange:#f97316;--red:#e11d48;--blue:#0ea5e9;--cyan:#06b6d4;--violet:#7c3aed;--yellow:#facc15;
  --shadow:0 14px 36px rgba(15,23,42,.10);--radius:18px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:linear-gradient(135deg,#edf7ef 0%,#f6f8fb 52%,#eef7ff 100%);color:var(--text);font-size:15px} button,input,select,textarea{font:inherit} button{border:0;cursor:pointer} img{max-width:100%;display:block}.hidden{display:none!important}.full{grid-column:1/-1;width:100%}
/* login */
.auth-screen{min-height:100vh;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at 12% 18%,rgba(250,204,21,.24),transparent 30%),radial-gradient(circle at 86% 78%,rgba(22,163,74,.32),transparent 34%),linear-gradient(135deg,#0b1220,#14532d)}
.auth-card{width:min(960px,96vw);min-height:520px;border-radius:30px;padding:42px;background:linear-gradient(90deg,rgba(15,23,42,.88),rgba(17,24,39,.72) 48%,rgba(255,255,255,.96) 48%);box-shadow:0 30px 80px rgba(0,0,0,.35);color:#fff;position:relative;overflow:hidden}.auth-card:before{content:'PDV AGRO';position:absolute;left:42px;bottom:42px;color:rgba(255,255,255,.09);font-size:76px;font-weight:900;letter-spacing:-4px}.auth-brand{width:44%;display:flex;gap:18px;align-items:center;margin-bottom:34px}.brandmark{width:76px;height:76px;border-radius:22px;display:grid;place-items:center;font-size:38px;background:linear-gradient(135deg,#bef264,#f59e0b);box-shadow:0 18px 34px rgba(0,0,0,.28)}.brandmark.small{width:54px;height:54px;font-size:28px;border-radius:16px}.auth-card h1{font-size:48px;line-height:1;margin:0 0 10px;letter-spacing:-2px}.auth-card p{margin:0;color:#dbeafe;line-height:1.5;font-size:17px}.auth-card .form-grid,.auth-card .actions,.auth-card .msg{width:42%;margin-left:auto}.auth-card label{color:#0f172a}.auth-card input{background:#fff}.auth-card .actions{margin-top:18px}.auth-card .btn.primary{background:#111827}.auth-card .btn.light{background:#e8eef6}.auth-card .msg{color:#9a3412}
/* base controls */
.form-grid{display:grid;gap:12px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.six{grid-template-columns:repeat(6,minmax(0,1fr))}label{font-weight:800;font-size:13px;display:flex;flex-direction:column;gap:7px;color:#334155}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:12px 13px;background:#fff;outline:none;color:var(--text)}input:focus,select:focus,textarea:focus{border-color:#86efac;box-shadow:0 0 0 4px rgba(22,163,74,.13)}textarea{min-height:82px;resize:vertical}.actions{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}.btn{padding:12px 16px;border-radius:14px;font-weight:900;transition:.14s;box-shadow:0 8px 22px rgba(15,23,42,.08)}.btn:hover{transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,#111827,#0f172a);color:#fff}.btn.light{background:#eef2f7;color:#111827}.mini{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;padding:10px 14px;border-radius:12px;font-weight:900}.msg{padding:12px 14px;border-radius:14px;margin:10px 0}.msg.warn{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}.msg.info{background:#ecfdf5;color:#14532d;border:1px solid #bbf7d0}
/* app shell */
#appScreen{min-height:100vh}.topbar{background:linear-gradient(180deg,#202938,#080d16);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 22px;box-shadow:0 12px 30px rgba(15,23,42,.22);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:14px}.brand h2{margin:0;font-size:28px;letter-spacing:-1px}.brand small{color:#cbd5e1}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.top-actions select{min-width:245px;background:#fff;color:#0f172a;border-radius:12px;border:0}
.ribbon{background:linear-gradient(180deg,#f8fafc,#e8edf3);border-bottom:1px solid #cbd5e1;display:grid;grid-template-columns:repeat(12,minmax(90px,1fr));gap:0;box-shadow:0 8px 20px rgba(15,23,42,.08);position:sticky;top:82px;z-index:8}.rib{min-height:92px;background:transparent;border-right:1px solid #d1d5db;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;color:#111827;transition:.14s}.rib b{font-size:32px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.08))}.rib span{font-size:12px;font-weight:900;letter-spacing:.02em}.rib:hover,.rib.active{background:#fff;box-shadow:inset 0 -4px 0 #16a34a}.rib[data-page="venda"].active,.rib[data-page="venda"]:hover{box-shadow:inset 0 -4px 0 #7c3aed}.rib[data-page="financeiro"].active,.rib[data-page="financeiro"]:hover{box-shadow:inset 0 -4px 0 #f59e0b}
.main{max-width:1360px;margin:0 auto;padding:24px}.page{display:none}.page.active{display:block}.welcome,.title{background:rgba(255,255,255,.92);border:1px solid rgba(226,232,240,.9);border-radius:22px;padding:20px 22px;margin-bottom:18px;box-shadow:var(--shadow)}.welcome{display:flex;align-items:center;justify-content:space-between;gap:14px}.welcome h3,.title h3{font-size:30px;margin:0;color:#0f172a}.welcome p,.title p{margin:6px 0 0;color:var(--muted);font-weight:600}.pill,.badge{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;color:#312e81;padding:7px 11px;border-radius:999px;font-size:12px;font-weight:900}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.orange{background:#ffedd5;color:#9a3412}
/* home tiles */
.tiles{display:grid;grid-template-columns:repeat(8,1fr);gap:12px}.tile,.banner{border:0;border-radius:0;min-height:118px;padding:16px;box-shadow:var(--shadow);overflow:hidden;position:relative}.tile{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#111827;border:2px solid rgba(255,255,255,.75)}.tile:after{content:'';position:absolute;inset:auto -20% -50% -20%;height:70%;background:rgba(255,255,255,.16);transform:rotate(-6deg)}.tile div{font-size:48px;z-index:1}.tile strong{font-size:18px;margin-top:8px;z-index:1}.tile small{font-size:12px;margin-top:6px;font-weight:800;z-index:1}.tile.sale{grid-column:span 2;grid-row:span 2;min-height:248px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff}.tile.sale div{font-size:90px}.tile.sale strong{font-size:34px;letter-spacing:-1px}.orange{background:linear-gradient(135deg,#fb923c,#ea580c);color:#fff}.orange2{background:linear-gradient(135deg,#f97316,#c2410c);color:#fff}.red{background:linear-gradient(135deg,#f43f5e,#be123c);color:#fff}.green{background:linear-gradient(135deg,#84cc16,#4d7c0f);color:#fff}.blue{background:linear-gradient(135deg,#38bdf8,#0284c7);color:#fff}.violet{background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff}.cyan{background:linear-gradient(135deg,#22d3ee,#0891b2);color:#fff}.banner{grid-column:span 2;min-height:210px;color:#fff;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start}.banner h3{font-size:24px;margin:0 0 10px;line-height:1.1}.banner p{font-size:27px;font-weight:900;margin:0}.banner span{font-weight:800;margin-top:auto;opacity:.95}.bgreen{background:linear-gradient(135deg,#65a30d,#16a34a)}.bblue{background:linear-gradient(135deg,#075985,#0ea5e9)}.bcyan{background:linear-gradient(135deg,#0f766e,#06b6d4)}.byellow{background:linear-gradient(135deg,#f59e0b,#facc15);color:#111827}.fruitline{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.fruitline img{width:58px;height:58px;object-fit:cover;background:#fff;border-radius:14px;border:2px solid rgba(255,255,255,.5)}
/* content */
.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.split.wide-left{grid-template-columns:1.15fr .85fr}.configgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel,.placeholder{background:rgba(255,255,255,.96);border:1px solid rgba(226,232,240,.95);border-radius:22px;padding:18px;box-shadow:var(--shadow)}.panel h4{margin:0 0 14px;color:#0f172a;font-size:19px}.tablewrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:11px 10px;text-align:left;vertical-align:top;border-bottom:1px solid #e5e7eb}th{background:#f8fafc;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.04em}td{font-size:14px}.search{width:100%;margin-bottom:12px}.fruitgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:13px}.fruitcard{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:12px;box-shadow:0 8px 24px rgba(15,23,42,.07);display:flex;flex-direction:column;gap:8px}.fruitcard img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:15px;background:#f8fafc}.fruitcard h4{margin:0;font-size:17px;color:#0f172a}.fruitcard p{margin:0;color:#64748b;font-size:13px}.fruitcard .btn,.fruitcard button{margin-top:auto}.stockgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.stock{background:#fff;border:1px solid #e5e7eb;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}.stock img{height:180px;width:100%;object-fit:cover}.stockbody{padding:15px}.stockbody h4{font-size:19px;margin:8px 0}.qr{width:88px;height:88px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:4px}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 16px}.docgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.doccard{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:20px;display:flex;flex-direction:column;gap:9px;align-items:flex-start;text-align:left;box-shadow:var(--shadow);min-height:170px}.doccard b{font-size:42px}.doccard strong{font-size:19px}.doccard span{color:var(--muted)}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:16px}.metrics div{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:16px;box-shadow:var(--shadow)}.metrics span{display:block;color:#64748b;font-weight:800}.metrics b{display:block;font-size:25px;margin-top:6px;color:#0f172a}.codebox img{margin-top:12px;max-width:220px}.permgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 0}.permgrid label{display:flex;flex-direction:row;align-items:center;font-weight:700}.muted{color:var(--muted);font-size:13px}.printarea{display:none}hr{border:0;border-top:1px solid #e5e7eb;margin:18px 0}
@media(max-width:1100px){.ribbon{top:90px;grid-template-columns:repeat(6,1fr)}.tiles{grid-template-columns:repeat(4,1fr)}.tile.sale,.banner{grid-column:span 2}.split,.split.wide-left,.configgrid{grid-template-columns:1fr}.metrics{grid-template-columns:repeat(2,1fr)}.auth-card{background:#fff;color:#0f172a}.auth-card:before{display:none}.auth-brand,.auth-card .form-grid,.auth-card .actions,.auth-card .msg{width:100%;margin-left:0}.auth-card p{color:#475569}}
@media(max-width:720px){.topbar{position:relative;align-items:flex-start;flex-direction:column}.ribbon{position:relative;top:0;grid-template-columns:repeat(3,1fr)}.main{padding:12px}.tiles{grid-template-columns:repeat(2,1fr)}.tile.sale,.banner{grid-column:span 2}.form-grid.two,.form-grid.six,.metrics,.permgrid{grid-template-columns:1fr}.welcome{align-items:flex-start;flex-direction:column}.welcome h3,.title h3{font-size:24px}.auth-card{padding:24px}.auth-card h1{font-size:34px}}
@media print{body *{visibility:hidden}.printarea,.printarea *{visibility:visible}.printarea{display:block;position:absolute;left:0;top:0;width:58mm;padding:8px;background:#fff;color:#000;font-family:monospace;font-size:11px}.printarea.w80{width:80mm}}


/* HOTFIX V4.3 - fluxo claro para produtos e estoque */
.title.estoque-title{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.title-actions{margin:0}.active-tab{background:#111827!important;color:#fff!important}.empty-state{background:rgba(255,255,255,.96);border:1px dashed #94a3b8;border-radius:22px;padding:24px;box-shadow:var(--shadow);grid-column:1/-1}.empty-state h3{margin:0 0 8px;font-size:24px}.empty-state p{margin:0 0 14px;color:#475569;font-weight:600;line-height:1.5}.empty-state .actions{margin:14px 0 0}.helper-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:14px;box-shadow:0 8px 24px rgba(15,23,42,.07);display:flex;flex-direction:column;gap:8px}.helper-card strong{font-size:18px}.helper-card small{color:#64748b;line-height:1.35}.fruitcard .fruit-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:auto}.fruitcard .stock-zero{color:#64748b;font-weight:800}.fruitcard .stock-ok{color:#166534;font-weight:900}.rib span{white-space:nowrap}.shortcut-row{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}.shortcut-row .btn{box-shadow:none}



/* Racavalli ajustes V4.4 */
.brand-logo-login{width:110px;max-height:90px;object-fit:contain;background:#fff;border-radius:18px;padding:10px;box-shadow:0 18px 34px rgba(0,0,0,.25)}
.brand-logo-top{width:64px;height:54px;object-fit:contain;background:#fff;border-radius:14px;padding:6px;box-shadow:0 8px 18px rgba(0,0,0,.18)}
.auth-cadastro{width:42%;margin-left:auto;background:rgba(255,255,255,.96);border:1px solid #e5e7eb;border-radius:18px;padding:14px;color:#0f172a;box-shadow:0 10px 26px rgba(15,23,42,.12)}
.auth-cadastro h3{margin:0 0 12px;color:#0f172a}.muted{color:#64748b;font-size:13px;line-height:1.45}.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.metrics>div{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:16px;box-shadow:var(--shadow)}.metrics span{display:block;color:#64748b;font-weight:800;font-size:12px;text-transform:uppercase}.metrics b{display:block;font-size:23px;margin-top:6px;color:#0f172a}.inline-actions{display:flex;gap:8px;flex-wrap:wrap}.retirada-mark{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;padding:8px 10px;border-radius:12px;font-weight:900;font-size:12px}
@media(max-width:900px){.auth-card{background:#fff;color:#0f172a}.auth-brand,.auth-card .form-grid,.auth-card .actions,.auth-card .msg,.auth-cadastro{width:100%;margin-left:0}.auth-card p{color:#64748b}.metrics{grid-template-columns:1fr 1fr}}


/* AJUSTE V4.4.1 - Cadastro novo usuário e rodapé padrão */
.auth-cadastro{
  width:min(520px,52%);
  min-width:420px;
  padding:24px;
}
.auth-cadastro .form-grid,
.auth-cadastro .actions,
.auth-cadastro .msg{
  width:100%!important;
  margin-left:0!important;
}
.auth-cadastro .form-grid.two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.auth-cadastro input{
  min-width:0;
}
.auth-cadastro .actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.auth-cadastro .actions .btn{
  width:100%;
  white-space:normal;
  min-height:54px;
}
.system-footer{
  max-width:1360px;
  margin:4px auto 24px;
  padding:16px 22px;
  text-align:center;
  color:#475569;
  font-size:13px;
  font-weight:700;
  line-height:1.5;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(226,232,240,.9);
  border-radius:18px;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
}
.system-footer strong{color:#14532d;}
@media(max-width:1100px){
  .auth-cadastro{width:100%;min-width:0;margin-left:0;}
}
@media(max-width:620px){
  .auth-cadastro{padding:18px;}
  .auth-cadastro .form-grid.two,
  .auth-cadastro .actions{grid-template-columns:1fr;}
  .system-footer{margin:4px 12px 18px;font-size:12px;padding:14px;}
}
