:root{
  --navy:#15512c; --navy2:#2c6b44; --orange:#1f7d40; --bg:#f3f5f3; --card:#fff;
  --line:#dde2dd; --txt:#222a25; --mut:#697269; --ok:#15803d; --bad:#b3261e; --warn:#b45309;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:'Montserrat','Segoe UI',Arial,sans-serif}
body{background:var(--bg);color:var(--txt);font-size:14px}
button{cursor:pointer;font-size:13px}
input,select,textarea{font-size:13px;padding:6px 8px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--txt)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--navy2);outline-offset:-1px}
input[type=number]{text-align:right}
.btn{border:none;border-radius:8px;padding:9px 16px;font-weight:600;color:#fff;background:var(--navy)}
.btn:hover{background:var(--navy2)}
.btn.orange{background:var(--orange)} .btn.orange:hover{background:#18672f}
.btn.green{background:var(--ok)} .btn.red{background:var(--bad)}
.btn.ghost{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.btn.sm{padding:5px 10px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.badge{display:inline-block;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px}
.b-rascunho{background:#e5e7eb;color:#374151}
.b-pendente{background:#fef3c7;color:var(--warn)}
.b-aprovado{background:#dcfce7;color:var(--ok)}
.b-rejeitado{background:#fee2e2;color:var(--bad)}
.hidden{display:none!important}

/* LOGIN */
#loginView{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#123f24 0%,#184d2c 55%,#21603a 100%)}
.loginBox{background:#fff;border-radius:12px;padding:36px;width:380px;box-shadow:0 14px 38px rgba(15,45,25,.20)}
.loginBox h1{font-size:20px;color:var(--navy);margin-bottom:2px}
.loginBox .sub{color:var(--mut);font-size:13px;margin-bottom:22px}
.loginBox label{display:block;font-size:12px;font-weight:600;color:var(--mut);margin:12px 0 4px}
.loginBox input{width:100%}
.loginBox .btn{width:100%;margin-top:20px;padding:11px}
.logoMark{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.logoSq{width:42px;height:42px;border-radius:9px;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:19px}
/* BRAND WORDMARK */
.wordmark{font-family:'Saira Condensed','Arial Narrow',sans-serif;font-style:italic;font-weight:800;line-height:.8;color:#fff;display:inline-flex;flex-direction:column;text-transform:uppercase;white-space:nowrap}
.wordmark .wm-1{font-size:.66em;letter-spacing:.05em}
.wordmark .wm-2{font-size:1.16em;letter-spacing:.01em}
.wordmark .wm-2 em{font-style:italic;font-size:.46em;font-weight:700;vertical-align:.62em;margin-right:.14em;letter-spacing:0}
.wordmark.badge{background:var(--navy);padding:.34em .52em;border-radius:.42em}
header.top .hbar{width:2px;height:30px;background:#ffffff55;border-radius:2px;margin:0 2px}
.loginBrand{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:22px}
.loginBrand .tagline{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:10px;letter-spacing:1.8px;color:var(--navy2);text-transform:uppercase;margin-top:11px;white-space:nowrap}
.loginSys{margin-top:15px}
.loginSys b{display:block;color:var(--navy);font-size:15px;font-weight:700}
.loginSys span{font-size:12px;color:var(--mut)}
.loginErr{color:var(--bad);font-size:12px;margin-top:10px;min-height:16px}
.demoHint{margin-top:18px;border-top:1px dashed var(--line);padding-top:12px;font-size:11px;color:var(--mut);line-height:1.7}

/* APP SHELL */
#appView{min-height:100vh}
header.top{background:var(--navy);color:#fff;display:flex;align-items:center;gap:14px;padding:10px 22px;position:sticky;top:0;z-index:50}
header.top .logoSq{width:34px;height:34px;font-size:15px}
header.top h1{font-size:15px;font-weight:700}
header.top .sub{font-size:11px;opacity:.75}
.spacer{flex:1}
.userChip{text-align:right;font-size:12px;line-height:1.4}
.userChip b{display:block}
.roleTag{font-size:10px;background:#ffffff1f;border:1px solid #ffffff4d;padding:1px 9px;border-radius:99px;font-weight:600;letter-spacing:.3px}
/* Botão hambúrguer (abre/fecha o menu) */
.hamburger{background:transparent;border:1px solid #ffffff4d;color:#fff;border-radius:8px;width:38px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex:none}
.hamburger:hover{background:#ffffff1f}
.hamburger svg{width:20px;height:20px}

/* SHELL com menu lateral */
.shell{display:flex;align-items:flex-start}
#appView.sidebar-collapsed #sidebar{display:none}
#sidebar{flex:none;width:208px;background:#fff;border-right:1px solid var(--line);padding:12px 10px;position:sticky;top:54px;height:calc(100vh - 54px);overflow:auto}
#sidebar .navLabel{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--mut);font-weight:700;padding:6px 12px 6px}
#sidebar .navItem{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:transparent;color:var(--txt);font-weight:600;font-size:13px;padding:9px 12px;border-radius:9px;cursor:pointer;font-family:inherit;margin-bottom:2px}
#sidebar .navItem:hover{background:#eef3ee}
#sidebar .navItem.active{background:var(--navy);color:#fff}
#sidebar .navItem svg{width:18px;height:18px;flex:none;color:var(--navy)}
#sidebar .navItem.active svg{color:#fff}
#sidebar .navSep{height:1px;background:var(--line);margin:8px 8px}
main{flex:1;min-width:0;max-width:1180px;margin:0;padding:16px 20px}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.toolbar h2{font-size:18px;color:var(--navy);margin-right:auto}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px}
table.list{width:100%;border-collapse:collapse}
table.list th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);text-align:left;padding:8px 10px;border-bottom:2px solid var(--line)}
table.list td{padding:10px;border-bottom:1px solid var(--line);font-size:13px}
table.list tr:hover td{background:#f8fafc}
.statRow{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stat .n{font-size:26px;font-weight:800;color:var(--navy)}
.stat .l{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px}

/* FORM */
.formGrid{display:grid;grid-template-columns:repeat(12,1fr);gap:10px}
.fg{display:flex;flex-direction:column;gap:3px}
.fg label{font-size:11px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.3px}
.fg input,.fg select{width:100%}
.c2{grid-column:span 2}.c3{grid-column:span 3}.c4{grid-column:span 4}.c6{grid-column:span 6}.c12{grid-column:span 12}
.secTitle{background:transparent;color:var(--navy);font-size:11px;font-weight:700;letter-spacing:.7px;padding:0 0 6px 0;border-bottom:1px solid var(--line);margin:12px 0 9px;text-transform:uppercase;display:flex;align-items:center;gap:9px}
.secTitle::before{content:"";width:3px;height:13px;background:var(--orange);border-radius:2px;display:inline-block;flex:none}
.card>.secTitle:first-child{margin-top:0}
table.grid{width:100%;border-collapse:collapse;font-size:12px}
table.grid th{background:#eef2f7;border:1px solid var(--line);padding:5px 6px;font-size:11px;color:var(--navy)}
table.grid td{border:1px solid var(--line);padding:3px;text-align:center}
table.grid td input{width:100%;border:none;border-radius:0;text-align:right;padding:5px 6px;background:#fffdf5}
table.grid td input:focus{outline:2px solid var(--orange)}
table.grid td.calc{background:#f1f5f9;font-weight:600;color:var(--navy);padding:5px 6px;text-align:right}
table.grid td.calcC{background:#f1f5f9;font-weight:700;text-align:center}
.resBox{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.resItem{border:1px solid var(--line);border-radius:9px;padding:10px 12px;background:#f8fafc}
.resItem .l{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.4px}
.resItem .v{font-size:18px;font-weight:800;color:var(--navy)}
.ok{color:var(--ok)!important}.bad{color:var(--bad)!important}
.stickyActions{position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg) 30%);padding:14px 0 4px;display:flex;gap:10px;justify-content:flex-end}

/* APPROVAL / HISTORY */
.histItem{border-left:3px solid var(--line);padding:4px 0 4px 12px;margin-bottom:8px;font-size:12px;color:var(--mut)}
.histItem b{color:var(--txt)}
.motivoBox{background:#fef2f2;border:1px solid #fecaca;border-radius:9px;padding:12px;margin-bottom:14px;font-size:13px;color:var(--bad)}

/* ASSINATURA */
.sigCanvasWrap{border:2px dashed var(--line);border-radius:10px;background:#fff;display:inline-block;touch-action:none}
.sigCanvasWrap canvas{display:block;border-radius:10px;cursor:crosshair}
.sigPreview{border:1px solid var(--line);border-radius:10px;background:#fff;padding:10px;display:inline-block}
.sigPreview img{max-height:90px;display:block}

/* ===================== HOME / MENU PRINCIPAL ===================== */
.homeWrap{padding-top:4px}
.homeHero{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.homeHero h2{font-size:25px;color:var(--navy);font-weight:800;letter-spacing:.2px}
.homeHero .greet{font-size:13px;color:var(--mut);margin-top:4px}
.homeHero .date{font-size:12px;color:var(--mut);text-align:right}
.appGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:18px}
.appCard{position:relative;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 20px;text-align:left;display:flex;flex-direction:column;gap:13px;min-height:206px;cursor:pointer;font-family:inherit;
  transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;overflow:hidden}
.appCard::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .18s ease}
.appCard:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(15,45,25,.15);border-color:var(--navy2)}
.appCard:hover::after{transform:scaleY(1)}
.appCard .ico{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;flex:none;background:linear-gradient(150deg,var(--navy),var(--navy2));box-shadow:0 6px 14px rgba(21,81,44,.28)}
.appCard .ico svg{width:28px;height:28px}
.appCard h3{font-size:17px;color:var(--navy);font-weight:700}
.appCard p{font-size:12.5px;color:var(--mut);line-height:1.5;flex:1}
.appCard .go{font-size:12px;font-weight:700;color:var(--orange);letter-spacing:.3px}
.appCard.soon .ico{background:linear-gradient(150deg,#8f998f,#aab3aa);box-shadow:none}
.pillNew{position:absolute;top:13px;right:13px;background:var(--orange);color:#fff;font-size:10px;font-weight:800;letter-spacing:.6px;padding:3px 10px;border-radius:99px;text-transform:uppercase;box-shadow:0 3px 8px rgba(31,125,64,.35)}
.pillSoon{align-self:flex-start;font-size:10px;font-weight:700;color:var(--warn);background:#fef3c7;border-radius:99px;padding:3px 10px;letter-spacing:.4px;text-transform:uppercase}
.homeBtn{cursor:pointer;border:none;background:transparent;padding:0}

/* MODULO EM DESENVOLVIMENTO */
.soonView{text-align:center;padding:54px 20px}
.soonView .bigIco{width:86px;height:86px;border-radius:22px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(150deg,var(--navy),var(--navy2));box-shadow:0 10px 24px rgba(21,81,44,.3)}
.soonView .bigIco svg{width:44px;height:44px}
.soonView h2{font-size:22px;color:var(--navy);margin-bottom:8px}
.soonView p{color:var(--mut);max-width:460px;margin:0 auto 22px;line-height:1.65;font-size:13.5px}

/* ===================== SPLASH (overlay via iframe) ===================== */
#splashHost{position:fixed;inset:0;z-index:100000;background:#0c0e10;opacity:1;transition:opacity .5s ease}
#splashHost.hide{opacity:0;pointer-events:none}
#splashHost iframe{width:100%;height:100%;border:0;display:block;background:#0c0e10}

/* ===================== PAINEL / DASHBOARD ===================== */
.kpiRow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px}
.kpiIco{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex:none;box-shadow:0 6px 14px rgba(21,81,44,.22)}
.kpiIco svg{width:22px;height:22px}
.kpiN{font-size:24px;font-weight:800;color:var(--navy);line-height:1}
.kpiL{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.4px;margin-top:4px}
.kpiS{font-size:11px;color:var(--mut);margin-top:2px}
.dashGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dashGrid .card{margin-bottom:0}
.vbars{display:flex;align-items:flex-end;gap:8px;height:168px;padding-top:18px}
.vbar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:6px}
.vbarFill{width:100%;max-width:46px;border-radius:6px 6px 0 0;min-height:3px;position:relative;display:flex;justify-content:center;transition:height .45s ease}
.vbarFill span{position:absolute;top:-16px;font-size:11px;font-weight:700;color:var(--navy)}
.vbarLbl{font-size:10px;color:var(--mut);white-space:nowrap}
.donutWrap{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.donut{width:140px;height:140px;flex:none}
.donutN{font-size:26px;font-weight:800;fill:var(--navy)}
.donutL{font-size:10px;fill:var(--mut);text-transform:uppercase;letter-spacing:.5px}
.legend{display:flex;flex-direction:column;gap:8px;font-size:13px;flex:1;min-width:150px}
.legend>div{display:flex;align-items:center;gap:8px;color:var(--txt)}
.legend span{width:12px;height:12px;border-radius:3px;display:inline-block;flex:none}
.legend b{margin-left:auto;color:var(--navy)}
.hbars{display:flex;flex-direction:column;gap:11px;padding-top:4px}
.hbar .hbarTop{display:flex;justify-content:space-between;gap:10px;font-size:12px;margin-bottom:4px}
.hbar .hbarLbl{color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbar .hbarTop b{color:var(--navy);flex:none}
.hbarTrack{height:8px;background:#eef2ef;border-radius:99px;overflow:hidden}
.hbarFill{height:100%;border-radius:99px;transition:width .45s ease}
@media(max-width:900px){.kpiRow{grid-template-columns:repeat(2,1fr)}.dashGrid{grid-template-columns:1fr}}

/* ===================== MODAL + LINHA DO TEMPO ===================== */
.modalOverlay{position:fixed;inset:0;background:rgba(12,22,15,.55);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modalBox{background:#fff;border-radius:14px;width:100%;max-width:520px;max-height:85vh;overflow:auto;padding:20px;box-shadow:0 22px 60px rgba(0,0,0,.32)}
.modalHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.modalHead h3{color:var(--navy);font-size:17px;font-weight:700}
.tlStamp{border-radius:8px;padding:7px 10px;font-size:12px;font-weight:700;margin-bottom:12px}
.tlStamp.ok{background:#dcfce7;color:var(--ok)}
ul.tl{list-style:none;position:relative;margin:4px 0 0 4px;padding-left:24px}
ul.tl::before{content:"";position:absolute;left:8px;top:6px;bottom:8px;width:2px;background:var(--line)}
ul.tl li{position:relative;padding:0 0 16px 2px}
ul.tl li:last-child{padding-bottom:0}
ul.tl .dot{position:absolute;left:-24px;top:0;width:18px;height:18px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;background:var(--mut)}
ul.tl .dot.ok{background:var(--ok)} ul.tl .dot.bad{background:var(--bad)} ul.tl .dot.warn{background:var(--warn)} ul.tl .dot.info{background:var(--navy2)}
ul.tl .ev{font-weight:700;color:var(--txt);font-size:13px}
ul.tl .tlMeta{font-size:11px;color:var(--mut);margin-top:2px}
ul.tl .tlMotivo{font-size:12px;color:var(--bad);margin-top:3px}

/* ===================== ETIQUETAS / CERTIFICADO DE LOTE ===================== */
.etqSheet{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;background:#9aa3af;padding:18px;border-radius:12px}
.etqSheet.etq-cols-1{grid-template-columns:minmax(0,1fr);max-width:620px;margin:0 auto}
.etqCard{background:#fff;border:2px solid #111;font-size:11px;color:#111;overflow:hidden;break-inside:avoid;min-width:0}
.etqHead{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f3f4f3;border-bottom:2px solid #111}
.etqHead .etqLogo{flex:none}
.etqHead .etqLogo .wordmark{color:#fff}
.etqAddr{flex:1;min-width:0;font-size:9.5px;line-height:1.45;color:#1f3a27;text-align:center;word-break:break-word}
.etqAddr b{color:#15512c;font-size:11px;display:block}
.etqAddr b:last-child{display:block;margin-top:2px;font-size:11.5px}
.etqSeal{flex:none;width:78px;text-align:center}
.etqSeal .sealImg{width:72px;height:auto;display:block;margin:0 auto}
.etqDesc{padding:8px 12px;border-bottom:1px solid #111;word-break:break-word}
.etqDesc .k{font-weight:600;margin-right:6px}
table.etqTab{width:100%;border-collapse:collapse;table-layout:fixed}
table.etqTab td{border-bottom:1px solid #111;border-right:1px solid #111;padding:8px 10px;vertical-align:middle;word-break:break-word}
table.etqTab td:last-child{border-right:none}
table.etqTab tr:last-child td{border-bottom:none}
table.etqTab td.k{font-weight:600;width:24%;color:#222}
table.etqTab td.vv{text-align:center;font-weight:600}

/* PRINT DOCUMENT */
#docWrap{background:#9aa3af;padding:24px 0}
.docPage{width:210mm;min-height:280mm;margin:0 auto 18px;background:#fff;padding:12mm;box-shadow:0 4px 18px rgba(0,0,0,.3);font-size:11px;color:#000}
.docHead{display:flex;border:2px solid #000}
.docHead .dh1{flex:1;padding:8px;display:flex;align-items:center;gap:10px;border-right:2px solid #000}
.docHead .dh1 .t{font-size:15px;font-weight:800;letter-spacing:.5px}
.docHead .dh2{width:42%;display:flex;flex-direction:column}
.docHead .dh2 .a{padding:4px 8px;font-weight:700;border-bottom:1px solid #000;font-size:10px;background:#e8e8e8}
.docHead .dh2 .b{padding:6px 8px;font-weight:700;flex:1;display:flex;align-items:center}
.dRow{display:flex;border:1px solid #000;border-top:none}
.dCell{padding:4px 8px;border-right:1px solid #000;flex:1}
.dCell:last-child{border-right:none}
.dCell b{font-size:10px}
.dTitle{background:#11602c;color:#fff;font-weight:700;padding:5px 8px;border:1px solid #000;border-top:none;font-size:11px}
table.dt{width:100%;border-collapse:collapse;font-size:10px}
table.dt th{border:1px solid #000;background:#e8e8e8;padding:3px 4px}
table.dt td{border:1px solid #000;padding:3px 4px;text-align:center}
.dSig{display:flex;margin-top:26px;gap:30px}
.dSig .s{flex:1;text-align:center;font-size:10px}
.dSig .s .sigSlot{height:48px;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.dSig .s .sigSlot img{max-height:46px;max-width:95%;display:block}
.dSig .s .line{border-top:1px solid #000;margin-top:2px;padding-top:4px;font-weight:700}
.dFoot{margin-top:18px;border-top:2px solid var(--orange);padding-top:6px;text-align:center;font-size:9px;line-height:1.5}
.dObs{border:1px solid #000;padding:6px 8px;min-height:40px;font-size:10px;margin-top:-1px}
.aprStamp{margin-top:10px;border:2px solid var(--ok);color:var(--ok);border-radius:8px;padding:8px;text-align:center;font-weight:800;font-size:11px}
@media print{
  body *{visibility:hidden}
  #docWrap,#docWrap *{visibility:visible}
  #docWrap{position:absolute;left:0;top:0;width:100%;background:#fff;padding:0}
  .docPage{box-shadow:none;margin:0;width:auto;min-height:0;padding:8mm}
  /* folha de etiquetas / certificado — dimensionada para caber no A4 */
  #etqSheet,#etqSheet *{visibility:visible}
  #etqSheet{position:absolute;left:0;top:0;width:100%;background:#fff;padding:0;gap:5mm;
    grid-template-columns:repeat(2,minmax(0,1fr))}
  #etqSheet.etq-cols-1{grid-template-columns:minmax(0,1fr);max-width:none;margin:0}
  #etqSheet .etqCard{border-width:1px;font-size:9px}
  #etqSheet .etqHead{padding:6px 8px;gap:8px}
  #etqSheet .etqAddr{font-size:8px}
  #etqSheet .etqAddr b,#etqSheet .etqAddr b:last-child{font-size:9px}
  #etqSheet .etqSeal{width:56px}
  #etqSheet .etqSeal .sealImg{width:52px}
  #etqSheet .etqDesc{padding:5px 8px}
  #etqSheet table.etqTab td{padding:5px 8px}
  .noprint,#splashHost,#modalHost{display:none!important}
  @page{size:A4;margin:8mm}
}
