:root{--bg: #f4f6f9;--surface: #ffffff;--sidebar: #0f2a43;--sidebar-2: #0b2236;--primary: #1f7a4d;--primary-dark: #176039;--text: #1d2733;--muted: #6b7785;--border: #e3e8ee;--danger: #d64545;--danger-bg: #fdecec;--ok: #1f7a4d;--warn-bg: #fff7e6;--shadow: 0 1px 3px rgba(16, 30, 54, .08), 0 4px 16px rgba(16, 30, 54, .06);--radius: 10px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,system-ui,-apple-system,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px}code{font-family:ui-monospace,Cascadia Code,Consolas,monospace;color:var(--muted);font-size:12.5px}.layout{display:flex;min-height:100vh}.sidebar{width:248px;background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#e8eef5;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:20px 18px;font-weight:700;font-size:16px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-mark{font-size:22px}.nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;color:#c4d0dd;text-decoration:none;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:var(--primary);color:#fff}.nav-icon{width:20px;text-align:center;font-size:15px}.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:8px}.user-info{display:flex;flex-direction:column;line-height:1.3}.user-info strong{font-size:13px}.user-info span{font-size:11px;color:#9fb0c1}.content{flex:1;padding:24px 28px;overflow-x:auto;min-width:0}.page{max-width:1180px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.page-header h2{margin:0;font-size:22px}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.muted{color:var(--muted);font-size:13px}.btn{border:1px solid var(--border);background:#fff;color:var(--text);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,opacity .15s}.btn:hover{background:#f3f5f8}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-danger{color:var(--danger);border-color:#f0c4c4}.btn-danger:hover{background:var(--danger-bg)}.btn-ghost{background:transparent;border-color:#fff3;color:#dbe4ee}.btn-ghost:hover{background:#ffffff1a}.btn-sm{padding:5px 10px;font-size:12px}.btn-block{width:100%}.input,input,select,textarea{border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px;background:#fff;color:var(--text);font-family:inherit}.input{min-width:220px}input:focus,select:focus,textarea:focus{outline:2px solid rgba(31,122,77,.25);border-color:var(--primary)}.field{display:flex;flex-direction:column;gap:5px}.field>span{font-size:12.5px;font-weight:600;color:var(--muted)}.field-check{flex-direction:row;align-items:center;gap:8px}.field-inline{display:flex;align-items:center;gap:6px}.field-inline>span{font-size:12.5px;color:var(--muted);font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid .field-check,.form-grid p{grid-column:1 / -1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--border)}.table th{background:#fafbfc;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.table tbody tr:hover{background:#fafcfb}.table .num{text-align:right}.table .actions{text-align:right;white-space:nowrap}.table .actions .btn+.btn{margin-left:6px}.table .empty,.empty{text-align:center;color:var(--muted);padding:28px}.row-danger{background:var(--danger-bg)!important}.badge{display:inline-block;padding:3px 9px;border-radius:99px;font-size:11.5px;font-weight:700}.badge-ok{background:#e4f4ec;color:var(--ok)}.badge-off{background:#eef1f4;color:var(--muted)}.badge-count{background:#ffffff26;color:#fff}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warn{background:#fff7e6;color:#8a6d00}.alert{padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #f3c9c9}.alert-ok{background:#e4f4ec;color:var(--ok);border:1px solid #bfe5d0}.login-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0f2a43,#1f7a4d);padding:20px}.login-card{background:#fff;padding:32px;border-radius:14px;width:100%;max-width:360px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.login-brand{text-align:center;margin-bottom:6px}.login-brand .brand-mark{font-size:40px}.login-brand h1{margin:8px 0 2px;font-size:22px}.login-brand p{margin:0;color:var(--muted);font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1e3273;display:grid;place-items:center;padding:20px;z-index:50}.modal{background:#fff;border-radius:12px;width:100%;max-width:520px;box-shadow:var(--shadow)}.modal-wide{max-width:760px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:17px}.modal-close{border:none;background:none;font-size:24px;line-height:1;cursor:pointer;color:var(--muted)}.modal-body{padding:20px}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.rotas-layout{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start}.rotas-cards{display:flex;flex-direction:column;gap:10px}.rota-card{text-align:left;background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;box-shadow:var(--shadow);transition:border-color .15s,transform .05s}.rota-card:hover{border-color:#c7d2dd}.rota-card.active{border-color:var(--primary);box-shadow:0 0 0 2px #1f7a4d2e}.rota-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.rota-card-top .badge-count{background:var(--primary)}.rota-card-meta{display:flex;flex-direction:column;gap:3px;font-size:12.5px;color:var(--muted)}.rotas-detalhe{padding:18px}.detalhe-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.detalhe-header h3{margin:0 0 2px}.detalhe-acoes{display:flex;gap:8px}.romaneio-box{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 14px;margin-bottom:14px;background:#f6f8fb;border:1px solid var(--border);border-radius:10px}.romaneio-info{display:flex;flex-direction:column;gap:2px}.romaneio-acoes{display:flex;gap:8px}.ordered-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.ordered-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:grab}.ordered-item:active{cursor:grabbing}.drag-handle{color:#b7c0ca;font-size:16px}.ordem-num{width:26px;height:26px;display:grid;place-items:center;background:#eef4f0;color:var(--primary);border-radius:50%;font-weight:700;font-size:12px}.ordered-nome{flex:1}.sse-status{font-size:12.5px;font-weight:600;padding:4px 10px;border-radius:99px}.sse-status.on{color:var(--ok);background:#e4f4ec}.sse-status.off{color:var(--muted);background:#eef1f4}.coletas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.coleta-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow);border-left:4px solid var(--primary);animation:pop .25s ease}.coleta-card.alerta{border-left-color:var(--danger);background:var(--danger-bg)}@keyframes pop{0%{transform:scale(.98);opacity:0}to{transform:scale(1);opacity:1}}.coleta-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.coleta-card-head strong{display:block}.competencia{background:var(--sidebar);color:#fff;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:700;white-space:nowrap}.coleta-card-body{margin:10px 0;display:flex;flex-direction:column;gap:6px}.coleta-linha{display:flex;align-items:center;gap:10px}.coleta-linha.sub{padding-left:6px;opacity:.9}.tanque-chip{background:#eef4f0;color:var(--primary);font-weight:700;border-radius:6px;padding:2px 8px;font-size:12px}.tanque-chip.alt{background:#eef1f8;color:#3a59b5}.prod-nome-linha{display:flex;align-items:center;gap:6px}.obs-icon{font-size:14px;line-height:1;cursor:help}.coleta-obs{background:#fff7e6;border-left:3px solid #e0a800;border-radius:6px;padding:6px 10px;font-size:13px;color:#5c4a00;font-style:italic}.coleta-card-foot{display:flex;justify-content:space-between;font-size:12px;padding-top:8px;border-top:1px dashed var(--border)}.coleta-card-total{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.report-summary{display:flex;gap:14px;margin-bottom:16px;flex-wrap:wrap}.kpi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 18px;box-shadow:var(--shadow);min-width:150px}.kpi span{display:block;font-size:12.5px;color:var(--muted)}.kpi strong{font-size:22px}.kpi strong.danger,.danger{color:var(--danger)}.kpi strong.ok,.ok{color:var(--ok)}.recoleta-info{display:flex;flex-direction:column;gap:2px;align-items:flex-start}.recoleta-info small{color:var(--muted);font-size:11.5px;line-height:1.3}.tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.tab{border:1px solid var(--border);background:#fff;padding:7px 14px;border-radius:99px;cursor:pointer;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}.tab.active{background:var(--sidebar);color:#fff;border-color:var(--sidebar)}.tab-badge{background:var(--danger);color:#fff;border-radius:99px;padding:0 7px;font-size:11px}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.dash-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow);text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:8px;transition:transform .08s}a.dash-card:hover{transform:translateY(-2px)}.dash-card span{color:var(--muted);font-size:13px}.dash-card strong{font-size:26px}.dash-card.primary{background:var(--primary);color:#fff}.dash-card.primary span{color:#ffffffd9}.dash-card.alerta{border-color:#f0c4c4}.dash-card.alerta strong{color:var(--danger)}.config-card{padding:22px;display:flex;flex-direction:column;gap:14px;max-width:560px}.config-card h3{margin:0}.centered-screen{min-height:100vh;display:grid;place-items:center}.spinner{width:36px;height:36px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media print{.sidebar,.no-print,.btn{display:none!important}.content{padding:0}.card{box-shadow:none;border:1px solid #ccc}}@media (max-width: 900px){.rotas-layout,.form-grid{grid-template-columns:1fr}.sidebar{width:64px}.brand-text,.nav-item span:not(.nav-icon),.user-info{display:none}.dash-cols{grid-template-columns:1fr}}.alert-info{background:#eaf3fb;color:#1c5a96;border:1px solid #c8dcf0}.btn-warn{color:#8a6d00;border-color:#ecd9a3}.btn-warn:hover{background:var(--warn-bg)}.row-warn{background:var(--warn-bg)!important}.tendencia{display:block;font-size:12px;font-weight:600;margin-top:4px}.tendencia.up{color:var(--ok)}.tendencia.down{color:var(--danger)}.dash-card small{font-weight:500}.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.card .card-title{padding:14px 16px 0;margin:0 0 8px;font-size:14px}.card-title .muted{font-weight:400;font-size:12px}.card>.muted{display:block;padding:10px 16px}.table-compact th,.table-compact td{padding:7px 12px}.barchart{display:flex;align-items:flex-end;gap:3px;height:160px;padding:12px 16px 4px;overflow-x:auto}.barchart-col{flex:1 0 14px;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.barchart-bar{width:70%;min-height:2px;background:var(--primary);border-radius:3px 3px 0 0;transition:height .2s}.barchart-label{font-size:9px;color:var(--muted);margin-top:3px}.coleta-card.ocorrencia{border-left:4px solid var(--danger);background:var(--danger-bg)}.super-wrap{max-width:920px;margin:0 auto;padding:28px 20px 48px}.super-wrap .card{padding:18px;margin-bottom:20px}.super-wrap .card h2{margin:0 0 14px;font-size:18px}.super-form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-items:end}.super-form .btn{grid-column:1 / -1;justify-self:start}.super-wrap .alert-ok code{background:#0000000f;padding:1px 6px;border-radius:4px}@media (max-width: 700px){.super-form{grid-template-columns:1fr}}
