:root{
  --bg0:#0f1a16;
  --bg1:#10241d;
  --card:rgba(255,255,255,.86);
  --card2:rgba(255,255,255,.72);
  --text:#0e1512;
  --muted:#3a4a44;
  --line:rgba(15,26,22,.14);
  --shadow:0 18px 55px rgba(0,0,0,.22);
  --shadow2:0 12px 28px rgba(0,0,0,.18);

  --accent:#1e6a4d;
  --accent2:#d19a2b;
  --danger:#b42318;
  --ok:#027a48;

  --radius:16px;
  --radius2:12px;
  --pad:16px;
  --pad2:12px;
  --mono:ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  --sans:"Segoe UI Variable Text","Segoe UI",system-ui,-apple-system,Arial;
  --serif:ui-serif, Georgia, Cambria, "Times New Roman", Times;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  font-family:var(--sans);
  background:linear-gradient(180deg,var(--bg0),var(--bg1));
}

.bg{position:fixed;inset:0;pointer-events:none;overflow:hidden}
.halo{
  position:absolute;
  width:1200px;height:1200px;
  left:50%;top:-520px;transform:translateX(-50%);
  background:radial-gradient(circle at 50% 50%, rgba(209,154,43,.35), rgba(30,106,77,.05) 52%, rgba(15,26,22,0) 70%);
  filter:blur(12px);
  opacity:.9;
}
.grain{
  position:absolute;inset:-40px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
  opacity:.18;
}

.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:12px 16px;
  backdrop-filter:saturate(1.2) blur(10px);
  background:linear-gradient(180deg, rgba(15,26,22,.82), rgba(15,26,22,.55));
  border-bottom:1px solid rgba(255,255,255,.10);
}

.brand{display:flex;gap:14px;align-items:center;color:rgba(255,255,255,.92);min-width:0;flex:1 1 340px}
.brand-logo{
  width:88px;
  height:88px;
  object-fit:contain;
  border-radius:12px;
  background:rgba(255,255,255,.92);
  padding:6px;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 10px 22px rgba(0,0,0,.22);
}
.brand-video{
  width:88px;
  height:88px;
  object-fit:cover;
  border-radius:12px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 10px 22px rgba(0,0,0,.22);
}
.mark{width:22px;height:22px;border-radius:7px;background:linear-gradient(135deg,var(--accent2),var(--accent));box-shadow:0 10px 22px rgba(0,0,0,.28)}
.brand-title{font-family:var(--sans);font-size:18px;font-weight:750;letter-spacing:.16em;text-transform:uppercase;line-height:1.05}
.brand-sub{margin-top:4px;font-size:13px;color:rgba(255,255,255,.72);letter-spacing:.02em}

.top-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap;flex:1 1 520px}
.top-actions-split{justify-content:flex-end;gap:14px;align-items:center}
.top-actions-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:8px 10px;border:1px solid rgba(255,255,255,.10);border-radius:18px;background:rgba(255,255,255,.05);box-shadow:0 8px 18px rgba(0,0,0,.12)}
.top-actions-nav{justify-content:flex-start;background:rgba(209,154,43,.08);border-color:rgba(209,154,43,.16)}
.top-actions-admin{justify-content:center;background:rgba(44,84,160,.10);border-color:rgba(94,145,255,.18)}
.top-actions-links{justify-content:flex-end;background:rgba(255,255,255,.04)}
.top-actions .btn{min-height:46px;padding:11px 16px;border-radius:14px;font-size:13px;min-width:0}
.top-actions-group .btn{background:rgba(255,255,255,.04)}
.top-actions-admin .btn{background:rgba(94,145,255,.08);border-color:rgba(94,145,255,.20)}
.top-actions-links #btnAuth{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.09);color:rgba(255,255,255,.96)}
.top-actions-links #btnAuth:hover{background:rgba(255,255,255,.15)}

.shell{display:grid;grid-template-columns:248px minmax(0,1fr);gap:14px;max-width:none;margin:0;padding:14px 16px 16px;align-items:start}

body.nav-collapsed .shell{grid-template-columns:minmax(0,1fr);gap:0}
body.nav-collapsed .nav{display:none}

.nav{
  position:sticky;top:82px;align-self:start;
  display:flex;flex-direction:column;
  border-radius:var(--radius);
  padding:12px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow2);
  max-height:calc(100vh - 96px);
  overflow:auto;
  overscroll-behavior:contain;
  scrollbar-gutter:stable;
}
.nav nav{display:flex;flex-direction:column;gap:4px;min-height:0;padding-bottom:24px}
.nav-section{margin:10px 8px 4px;color:rgba(255,255,255,.55);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;
  border-radius:12px;
  color:rgba(255,255,255,.88);
  text-decoration:none;
  border:1px solid transparent;
  transition:transform .10s ease, background-color .12s ease, border-color .12s ease;
  position:relative;
}
.nav-item:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.nav-item.active{background:rgba(209,154,43,.14);border-color:rgba(209,154,43,.22)}
.nav-item.active::before{
  content:"";
  position:absolute;
  left:6px;
  top:8px;
  bottom:8px;
  width:3px;
  border-radius:99px;
  background:linear-gradient(180deg, rgba(209,154,43,.95), rgba(30,106,77,.95));
  opacity:.85;
}
.nav-foot{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.12)}
.mini{display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,.75);font-size:11px;padding:5px 6px}
.mini-v{color:rgba(255,255,255,.84);text-decoration:none;font-family:var(--mono);font-size:11px}

.main{min-height:calc(100vh - 140px);min-width:0}
.view{min-width:0}
.panel{min-width:0}
.panel-body{min-width:0}
.table-wrap{max-width:100%}
.view{display:flex;flex-direction:column;gap:14px;animation:fadeIn .24s ease-out}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.panel{
  border-radius:var(--radius);
  background:linear-gradient(180deg,var(--card),var(--card2));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.panel-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;padding:18px 18px 12px;border-bottom:1px solid var(--line)}
.panel-title{font-family:var(--serif);font-size:18px}
.panel-sub{margin-top:4px;color:var(--muted);font-size:13px}
.panel-body{padding:16px}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.span4{grid-column:span 4}
.span2{grid-column:span 2}
.span6{grid-column:span 6}
.span8{grid-column:span 8}
.span12{grid-column:span 12}

.stat{padding:14px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.55)}
.stat-k{color:var(--muted);font-size:12px;letter-spacing:.02em}
.stat-v{margin-top:6px;font-size:22px;font-family:var(--serif)}
.stat-h{margin-top:6px;font-size:12px;color:var(--muted)}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;margin:10px 0 12px}
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;min-width:0}
.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.panel-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;justify-content:flex-end;min-width:0}
.field{display:flex;flex-direction:column;gap:6px}
.field.field-warn input{border-color:rgba(209,154,43,.75);background:rgba(209,154,43,.10);box-shadow:0 0 0 1px rgba(209,154,43,.18) inset}
.field-note{font-size:11px;line-height:1.35;color:var(--muted)}
.field-note.warn{color:#9a6a13}
.label{font-size:12px;color:var(--muted)}

/* Forms: consistent grid sizing */
.field > input,
.field > select,
.field > textarea{width:100%}

/* Numeric readability */
input[inputmode="numeric"],
input[inputmode="decimal"],
input[type="number"]{text-align:right;font-variant-numeric:tabular-nums}

/* Calculated (readonly) fields */
input[readonly][name^="calc_"]{background:rgba(15,26,22,.06);border-color:rgba(15,26,22,.14);color:rgba(14,21,18,.88)}

input,select,textarea{
  font:inherit;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(15,26,22,.18);
  background:rgba(255,255,255,.88);
  outline:none;
}

.pwd-wrap{
  display:flex;
  gap:10px;
  align-items:center;
}
.pwd-wrap input{flex:1;min-width:0}
.pwd-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(15,26,22,.16);
  background:rgba(255,255,255,.66);
  color:rgba(15,26,22,.84);
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.pwd-toggle:hover{background:rgba(255,255,255,.78)}

input[type="range"].pct-range{padding:0;height:30px;background:transparent;border:none;accent-color:rgba(30,106,77,.95)}
.pct-row{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:nowrap}
.pct-range{flex:1;min-width:140px}
.pct-read{min-width:44px;padding:4px 6px;border-radius:10px;border:1px solid rgba(15,26,22,.14);background:rgba(255,255,255,.62);font-family:var(--mono);font-size:11px;text-align:right;white-space:nowrap}

/* Custom track with fill that changes color */
input[type="range"].pct-range{--pct:0%;--fill:rgb(180,35,24)}
input[type="range"].pct-range::-webkit-slider-runnable-track{
  height:10px;
  border-radius:999px;
  background:linear-gradient(90deg,
    var(--fill) 0%,
    var(--fill) var(--pct),
    rgba(15,26,22,.14) var(--pct),
    rgba(15,26,22,.14) 100%);
}
input[type="range"].pct-range::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:18px;height:18px;
  border-radius:50%;
  border:1px solid rgba(15,26,22,.22);
  background:rgba(255,255,255,.96);
  box-shadow:0 6px 16px rgba(0,0,0,.16);
  margin-top:-4px;
}

input[type="range"].pct-range::-moz-range-track{
  height:10px;
  border-radius:999px;
  background:linear-gradient(90deg,
    var(--fill) 0%,
    var(--fill) var(--pct),
    rgba(15,26,22,.14) var(--pct),
    rgba(15,26,22,.14) 100%);
}
input[type="range"].pct-range::-moz-range-thumb{
  width:18px;height:18px;
  border-radius:50%;
  border:1px solid rgba(15,26,22,.22);
  background:rgba(255,255,255,.96);
  box-shadow:0 6px 16px rgba(0,0,0,.16);
}
textarea{min-height:84px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(30,106,77,.55);box-shadow:0 0 0 4px rgba(30,106,77,.10)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.22);
  background:linear-gradient(135deg, rgba(209,154,43,.95), rgba(30,106,77,.95));
  color:rgba(255,255,255,.96);
  text-decoration:none;
  cursor:pointer;
  transition:transform .10s ease, filter .12s ease;
}
.btn:hover{filter:brightness(1.03)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:rgba(15,26,22,.06);border-color:rgba(15,26,22,.22);color:rgba(15,26,22,.86)}
.btn.ghost:hover{filter:none;background:rgba(15,26,22,.09)}
.topbar .btn.ghost{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.92)}
.topbar .btn.ghost:hover{filter:brightness(1.05);background:rgba(255,255,255,.12)}
.btn.danger{background:rgba(180,35,24,.92);border-color:rgba(180,35,24,.22)}
.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}
.btn.preset{padding:6px 9px;border-radius:999px}
.btn.preset.active{background:#fff3c4;border-color:rgba(209,154,43,.40);color:rgba(15,26,22,.86)}

/* Keep action/button typography consistent across tables and grids. */
.table-wrap .btn,
.grid-table .btn,
.grid-table .act-btn,
.mobile-card-actions .btn,
.actions .btn,
.actions .act-btn{
  font-size:12px;
  line-height:1.2;
  font-family:inherit;
  font-weight:600;
}

.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--line);-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:separate;border-spacing:0;background:rgba(255,255,255,.72)}
thead th{
  position:sticky;top:0;
  background:rgba(255,255,255,.92);
  text-align:left;
  font-size:12px;
  color:var(--muted);
  padding:10px 10px;
  border-bottom:1px solid var(--line);
}

thead th.sortable{cursor:pointer;user-select:none}
thead th.sortable:hover{color:rgba(15,26,22,.92)}
thead th.sorted-asc::after{content:" ^";font-family:var(--mono);opacity:.7}
thead th.sorted-desc::after{content:" v";font-family:var(--mono);opacity:.7}
tbody td{padding:10px 10px;border-bottom:1px solid rgba(15,26,22,.08);vertical-align:top}
tbody tr:hover{background:rgba(209,154,43,.06)}
tbody tr.hum-low{background:rgba(209,154,43,.10)}
tbody tr.hum-high{background:rgba(180,35,24,.10)}
th.actions, td.actions{white-space:nowrap;width:1%}

/* "Frame" visual para coluna de acoes (fixa na esquerda) */
th.actions{
  position:sticky;
  left:0;
  z-index:5;
  background:rgba(255,255,255,.94);
  border-right:1px solid var(--line);
  box-shadow:8px 0 14px rgba(0,0,0,.06);
}
td.actions{
  position:sticky;
  left:0;
  z-index:2;
  background:rgba(255,255,255,.80);
  border-right:1px solid rgba(15,26,22,.10);
  box-shadow:8px 0 14px rgba(0,0,0,.05);
}
tbody tr:hover td.actions{background:rgba(255,255,255,.88)}
tbody tr.hum-low td.actions{background:rgba(255,255,255,.86)}
tbody tr.hum-high td.actions{background:rgba(255,255,255,.86)}

/* Compact inputs inside rule tables (umidade faixas) */
.table-wrap table input[type="number"],
.table-wrap table input[type="text"]{
  width:100%;
  min-width:0;
  padding:7px 8px;
}
.table-wrap table select{
  width:100%;
  min-width:0;
  padding:7px 8px;
}

/* Contrato + Arquivos (regras destino) */
.contract-split{display:grid;grid-template-columns:1.15fr .85fr;gap:12px;align-items:start}
.contract-stack{display:block}
.contract-pane{min-width:0}
.contract-pane-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:8px}
.contract-pane-head .label{margin:0}
.contract-pane-head .hint{margin-top:4px}
.contract-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:10px}
.contract-upload-grid{display:grid;grid-template-columns:1.3fr 1fr .8fr auto;gap:10px;align-items:end}
.contract-grid-table td[data-label="Item"]{width:64px}
.contract-grid-table td[data-label="Data entrega"],
.contract-grid-table td[data-label="Data pagamento do silo"]{width:130px}
.contract-grid-table td[data-label="Responsável do contrato"]{width:240px}
.contract-grid-table td[data-label="Sacas"],
.contract-grid-table td[data-label="Preço travado (R$/sc)"]{width:120px}
.contract-grid-table input,
.contract-grid-table select{
  min-height:44px;
  height:44px;
  line-height:1.2;
}
.contract-grid-table td{vertical-align:middle}
.contract-grid-table input[name="ct_sacas"],
.contract-grid-table input[name="ct_preco"]{
  text-align:right;
  font-variant-numeric:tabular-nums;
}
.contract-grid-table td[data-label="Item"] .mono{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:34px;
  border-radius:999px;
  background:rgba(15,26,22,.06);
  border:1px solid rgba(15,26,22,.10);
}

.upload-row{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:10px;align-items:end}
.upload-row .btn{white-space:nowrap}
.upload-row input[type="file"]{width:100%}
@media (max-width: 920px){
  .contract-split{grid-template-columns:1fr}
  .contract-meta-grid{grid-template-columns:1fr}
  .contract-upload-grid{grid-template-columns:1fr}
  .umidade-checks{flex-direction:column;align-items:flex-start}
}

.contract-upload-grid .field{
  margin:0;
}
.contract-upload-grid .field .label{
  min-height:16px;
}
.umidade-mode-box{padding:12px;border:1px solid rgba(15,26,22,.10);border-radius:14px;background:rgba(255,255,255,.42)}
.umidade-checks{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.check-inline{display:flex;gap:8px;align-items:center;color:rgba(14,21,18,.88)}
.check-inline input{margin:0}
.uf-field input{max-width:96px}
@media (max-width: 520px){
  .upload-row{grid-template-columns:1fr}
  .upload-row .btn{width:100%}
}
.table-wrap table td{padding:8px 8px}

.rule-form{max-width:1080px;margin:0 auto}
.rule-wrap{max-width:860px;margin-left:auto;margin-right:auto}

.grid-in{width:84px;padding:7px 8px;border-radius:10px;border:1px solid rgba(15,26,22,.16);background:rgba(255,255,255,.72);font-family:var(--mono);font-size:12px}
.grid-in:focus{outline:none;border-color:rgba(209,154,43,.55);box-shadow:0 0 0 3px rgba(209,154,43,.18)}

/* Campos ajustados manualmente (romaneio) */
input[data-manual="1"],
select[data-manual="1"],
textarea[data-manual="1"]{
  background:#fff3c4 !important;
}
input[data-compare="higher"],
select[data-compare="higher"],
textarea[data-compare="higher"]{
  background:#ffd8d3 !important;
  border-color:rgba(180,35,24,.42) !important;
}
input[data-compare="lower"],
select[data-compare="lower"],
textarea[data-compare="lower"]{
  background:#fff3c4 !important;
  border-color:rgba(209,154,43,.42) !important;
}

/* Grid tables: consistent alignment & density */
.grid-table tbody tr:nth-child(even){background:rgba(15,26,22,.03)}
.grid-table tbody tr:hover{background:rgba(209,154,43,.06)}
.t-right{text-align:right}
.t-center{text-align:center}
.t-left{text-align:left}
.col-id{width:80px}
.col-date{width:140px}
.col-status{width:120px}

.act-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:10px;
  border:1px solid rgba(15,26,22,.16);
  background:rgba(255,255,255,.66);
  color:rgba(15,26,22,.84);
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.act-btn:hover{background:rgba(255,255,255,.78)}
.act-btn svg{opacity:.88}
.act-btn.danger{border-color:rgba(180,35,24,.30);background:rgba(180,35,24,.08);color:rgba(116,18,12,.95)}
.act-btn.danger:hover{background:rgba(180,35,24,.12)}

.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:32px;
  border-radius:10px;
  border:1px solid rgba(15,26,22,.16);
  background:rgba(255,255,255,.66);
  color:rgba(15,26,22,.84);
  cursor:pointer;
}
.icon-btn:hover{background:rgba(255,255,255,.78)}
.icon-btn svg{opacity:.88}
.icon-btn.danger{border-color:rgba(180,35,24,.30);background:rgba(180,35,24,.08);color:rgba(116,18,12,.95)}
.icon-btn.danger:hover{background:rgba(180,35,24,.12)}

tr.grid-skip{opacity:.45}
tr.grid-skip .grid-in{background:rgba(255,255,255,.45)}
code.mono{font-family:var(--mono);font-size:12px}

.charts{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.chart-card{grid-column:span 6;border:1px solid rgba(15,26,22,.12);border-radius:16px;background:rgba(255,255,255,.62);padding:14px;box-shadow:0 10px 22px rgba(0,0,0,.06)}
.chart-card.wide{grid-column:span 12}
.chart-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.chart-title{font-family:var(--serif);font-size:14px;color:rgba(14,21,18,.88)}
.chart-sub{font-size:12px;color:var(--muted)}
.chart-body{display:flex;gap:14px;align-items:center;margin-top:10px;flex-wrap:wrap}
.chart-body svg{display:block}
.legend{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}
.legend .row{display:flex;align-items:center;gap:8px}
.sw{width:10px;height:10px;border-radius:3px;box-shadow:0 0 0 1px rgba(15,26,22,.18) inset}
.bars{display:flex;flex-direction:column;gap:8px;width:100%}
.bar{display:grid;grid-template-columns:minmax(140px, 220px) 1fr minmax(300px, max-content);gap:10px;align-items:center}
.bar .name{font-size:12px;color:rgba(14,21,18,.86);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.bar .track{
  height:10px;
  border-radius:999px;
  background:rgba(15,26,22,.08);
  overflow:hidden;
  min-width:0;
  position:relative;
}
.bar .fill{
  position:absolute;
  left:0;
  top:0;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(30,106,77,.92), rgba(209,154,43,.92));
}

.bar .track[data-state="hit"] .fill{background:linear-gradient(90deg, rgba(30,106,77,.92), rgba(249,115,22,.92))}
.bar .track[data-state="near"] .fill{background:linear-gradient(90deg, rgba(30,106,77,.92), rgba(209,154,43,.92))}
.bar .track[data-state="over"] .fill{background:linear-gradient(90deg, rgba(30,106,77,.92), rgba(209,154,43,.92))}

/* Excedente: faixa vermelha por cima (lado direito) */
.bar .over{
  position:absolute;
  right:0;
  top:0;
  height:3px;
  border-radius:999px 0 0 999px;
  background:repeating-linear-gradient(
    45deg,
    rgba(180,35,24,.95) 0,
    rgba(180,35,24,.95) 7px,
    rgba(180,35,24,.65) 7px,
    rgba(180,35,24,.65) 12px
  );
  box-shadow:0 0 0 1px rgba(180,35,24,.15);
}
.bar .val{font-family:var(--mono);font-size:11px;color:var(--muted);text-align:right;white-space:nowrap;overflow:visible;text-overflow:clip}

@media (max-width: 780px){
  .bar{grid-template-columns:1fr}
  .bar .val{text-align:left;white-space:normal}
}


@media (max-width: 920px){
  .chart-card{grid-column:span 12}
}

.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(15,26,22,.12);background:rgba(255,255,255,.58);font-size:12px;color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.dot.warn{background:var(--accent2)}
.dot.hot{background:#f97316}
.dot.bad{background:var(--danger)}
.dot.muted{background:rgba(15,26,22,.35)}

.mini-map{width:100%;aspect-ratio:16/9;border-radius:14px;border:1px solid rgba(15,26,22,.12);background:rgba(255,255,255,.62);overflow:hidden}
.mini-map iframe{width:100%;height:100%;border:0;display:block}

.toast{
  position:fixed;right:18px;bottom:18px;z-index:80;
  min-width:260px;max-width:360px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,26,22,.16);
  box-shadow:var(--shadow2);
  border-radius:14px;
  padding:12px 12px;
  display:none;
}
.toast.show{display:block;animation:toastIn .18s ease-out}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.toast .t{font-family:var(--serif)}
.toast .m{margin-top:4px;color:var(--muted);font-size:13px}

.dlg{border:none;background:transparent;padding:0}
.dlg::backdrop{background:rgba(0,0,0,.55);backdrop-filter:blur(3px)}
.dlg-card{position:relative;width:min(780px, calc(100vw - 28px));max-height:calc(100dvh - 28px);display:flex;flex-direction:column;border-radius:18px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.78));box-shadow:var(--shadow);padding:0;overflow:hidden}
.dlg[data-size="wide"] .dlg-card{width:min(1180px, calc(100vw - 28px))}

.dlg-overlay{position:absolute;inset:0;z-index:30;background:rgba(0,0,0,.46);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:16px}
.dlg-overlay-card{width:min(640px, 100%);border-radius:16px;border:1px solid rgba(15,26,22,.16);background:rgba(255,255,255,.96);box-shadow:var(--shadow2);padding:14px 14px}
.dlg-overlay-title{font-family:var(--serif);font-size:15px;color:rgba(14,21,18,.90)}
.dlg-overlay-body{margin-top:8px;color:rgba(14,21,18,.86);font-size:13px}
.dlg-overlay-body .hint{margin-top:8px}
.dlg-overlay-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}
.dlg-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.dlg-title{font-family:var(--serif);font-size:16px}
.icon{border:none;background:transparent;font-size:22px;line-height:1;cursor:pointer;color:rgba(15,26,22,.65)}
.dlg-body{padding:16px;overflow:auto;flex:1;min-height:0}
.dlg-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;padding:12px 16px calc(12px + env(safe-area-inset-bottom, 0px));border-top:1px solid var(--line)}

.dlg[data-trava="1"] .dlg-card{border-color:rgba(209,154,43,.42)}
.dlg[data-trava="1"] .dlg-head{
  background:linear-gradient(180deg, rgba(209,154,43,.14), rgba(255,255,255,0));
}
.dlg[data-trava="1"] .dlg-body{
  background:linear-gradient(180deg, rgba(209,154,43,.12), rgba(255,255,255,0) 46%);
}

.dlg[data-variant="rev01"] .dlg-body{padding-top:0}
.dlg[data-variant="rev01"] #preview{
  position:sticky;
  top:0;
  z-index:6;
  margin:0 -16px 12px;
  padding:10px 16px;
  background:linear-gradient(180deg, rgba(255,255,255,.97), rgba(255,255,255,.86));
  border-bottom:1px solid rgba(15,26,22,.12);
  box-shadow:0 8px 18px rgba(0,0,0,.06);
}
.dlg[data-variant="rev01"] #preview .pill{background:rgba(255,255,255,.74)}

.dlg[data-variant="rev01"] #preview .prev-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.dlg[data-variant="rev01"] #preview .prev-title{font-family:var(--serif);font-size:14px;color:rgba(14,21,18,.88)}
.dlg[data-variant="rev01"] #preview .prev-body{margin-top:10px;display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px}
.dlg[data-variant="rev01"] #preview .pill{padding:5px 8px;font-size:11.5px}
.dlg[data-variant="rev01"] #preview .prev-details{width:100%;margin-top:6px}
.dlg[data-variant="rev01"] #preview .prev-details > summary{cursor:pointer;list-style:none;font-size:12px;color:var(--muted);user-select:none}
.dlg[data-variant="rev01"] #preview .prev-details > summary::-webkit-details-marker{display:none}
.dlg[data-variant="rev01"] #preview .prev-details[open] > summary{color:rgba(14,21,18,.88)}

.dlg[data-variant="rev01"][data-preview-collapsed="1"] #preview{padding:10px 16px}
.dlg[data-variant="rev01"][data-preview-collapsed="1"] #preview .prev-body{display:none}

.form-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}

/* Colheita: cards (dialog form) */
.colheita-form{display:flex;flex-direction:column;gap:26px}
.form-card{
  border:1px solid rgba(15,26,22,.12);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  box-shadow:0 12px 26px rgba(0,0,0,.06);
  overflow:hidden;
}
.form-card .form-grid{padding:16px}
.card-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px 12px;
  border-bottom:1px solid rgba(15,26,22,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.72));
}
.card-title{font-family:var(--serif);font-size:15px;color:rgba(14,21,18,.92);letter-spacing:.01em}
.card-actions{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;justify-content:flex-end}
.card-head .hint{margin-top:4px}
.form-card .card-body{padding:16px}

.pill-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px}

/* Rateio card refinements */
.rateio-cardx .card-head{align-items:center}
.rateio-cardx .card-title{font-size:18px;font-weight:600}
.rateio-head-left{min-width:220px}
.rateio-sub{margin-top:4px;font-size:13px;color:rgba(14,21,18,.62)}
.rateio-head-right{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.rateio-ctl{display:flex;gap:8px;align-items:center}
.rateio-ctl-label{font-size:12px;color:rgba(14,21,18,.62)}
.rateio-cardx select[name="talhao_sort"]{min-width:160px}

.rateio-cardx .rateio-grid{grid-template-columns:minmax(260px, 1fr) 120px 140px 56px}
.rateio-cardx .rateio-header{padding:12px 16px 10px;margin:0;border-bottom:1px solid rgba(15,26,22,.10)}
.rateio-cardx .rateio-header > div{font-size:13px;font-weight:600;color:rgba(14,21,18,.70)}

.rateio-cardx .rateio-body{gap:12px}
.rateio-cardx .rateio-item{background:rgba(255,255,255,.92);border-color:rgba(15,26,22,.12)}
.rateio-cardx .rateio-item:hover{background:rgba(255,255,255,.98)}

.rateio-cardx .rateio-cell[data-cell="pct"],
.rateio-cardx .rateio-cell[data-cell="kg"]{align-self:stretch;display:flex;align-items:center}

.rateio-cardx .rateio-rm{padding:7px 10px;min-width:44px}

.rateio-summary{padding:10px 12px;border-radius:14px;border:1px solid rgba(15,26,22,.12);background:rgba(255,255,255,.80)}
.rateio-summary.ok{border-color:rgba(30,106,77,.28);background:rgba(30,106,77,.06)}
.rateio-summary.warn{border-color:rgba(209,154,43,.38);background:rgba(209,154,43,.10)}
.rateio-summary-main{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.rateio-summary-note{margin-top:6px;font-size:12px;color:var(--muted)}

/* Colheita cards: let grid control field sizes */

/* rateio card inside colheita */
.form-card .rateio-header{padding:0 16px}
.form-card .rateio-body{padding:10px 16px 0}
.form-card .rateio-foot{padding:8px 16px 14px}

.form-card .rateio-grid{display:grid;grid-template-columns:1fr 120px 180px 90px;gap:10px;align-items:center}
.rateio-header{color:rgba(14,21,18,.70);font-size:13px;font-weight:600;letter-spacing:.01em;border-bottom:1px solid rgba(15,26,22,.10)}
.card-actions .mini{min-width:140px}
.card-actions .mini select{min-width:140px}
.rateio-cell input,.rateio-cell select{width:100%}

@media (max-width: 980px){
  .rateio-cardx .rateio-grid{grid-template-columns:1fr 1fr;grid-template-areas:"talhao talhao" "pct kg" "rm rm"}
  .rateio-cardx .rateio-header{display:none}
  .rateio-cardx .rateio-item{padding:12px}
  .rateio-cardx .rateio-cell[data-cell="talhao"]{grid-area:talhao}
  .rateio-cardx .rateio-cell[data-cell="pct"]{grid-area:pct}
  .rateio-cardx .rateio-cell[data-cell="kg"]{grid-area:kg}
  .rateio-cardx .rateio-cell[data-cell="rm"]{grid-area:rm;justify-content:stretch}
  .rateio-cardx .rateio-rm{width:100%}
}
.col6{grid-column:span 6}
.col4{grid-column:span 4}
.col3{grid-column:span 3}
.col2{grid-column:span 2}
.col8{grid-column:span 8}
.col12{grid-column:span 12}

.sec{display:flex;align-items:center;gap:10px;margin-top:6px}
.sec-title{font-family:var(--serif);font-size:14px;color:rgba(14,21,18,.88)}
.sec-line{height:1px;flex:1;background:rgba(15,26,22,.12)}

.hint{margin-top:10px;color:var(--muted);font-size:12px}

.ha-input{width:88px;min-width:88px;max-width:88px;text-align:right}

/* ACL helpers */
.acl-help{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(15,26,22,.12);
  background:rgba(255,255,255,.62);
}

.tri{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
.tri-opt{position:relative;display:block}
.tri-opt input{position:absolute;opacity:0;pointer-events:none}
.tri-opt span{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 8px;
  border-radius:12px;
  border:1px solid rgba(15,26,22,.14);
  background:rgba(255,255,255,.78);
  color:rgba(15,26,22,.86);
  font-size:12px;
  cursor:pointer;
  user-select:none;
}
.tri-opt span:hover{background:rgba(255,255,255,.92)}

.tri-opt.inherit input:checked + span{
  background:rgba(15,26,22,.06);
  border-color:rgba(15,26,22,.18);
}
.tri-opt.allow input:checked + span{
  background:rgba(2,122,72,.10);
  border-color:rgba(2,122,72,.30);
}
.tri-opt.deny input:checked + span{
  background:rgba(180,35,24,.10);
  border-color:rgba(180,35,24,.30);
}

.tri-opt input:focus + span{
  outline:none;
  box-shadow:0 0 0 4px rgba(30,106,77,.10);
  border-color:rgba(30,106,77,.55);
}

/* Audit UI */
.audit-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-end;flex-wrap:wrap}
.audit-title{font-family:var(--serif);font-size:28px;letter-spacing:.01em;color:rgba(14,21,18,.92)}
.audit-sub{margin-top:6px;color:rgba(14,21,18,.62);font-size:13px;max-width:72ch}
.audit-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.audit-cards{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.a-card{grid-column:span 3;border:1px solid rgba(15,26,22,.12);border-radius:18px;background:rgba(255,255,255,.82);box-shadow:0 10px 22px rgba(0,0,0,.05);padding:12px 12px;cursor:pointer;transition:transform .08s ease, border-color .08s ease}
.a-card:hover{transform:translateY(-1px);border-color:rgba(2,122,72,.26)}
.a-card .k{font-size:12px;color:rgba(14,21,18,.62)}
.a-card .v{margin-top:6px;font-family:var(--serif);font-size:20px;color:rgba(14,21,18,.92)}
.a-card .h{margin-top:6px;font-size:12px;color:var(--muted)}
.a-card.danger{border-color:rgba(180,35,24,.22)}
.a-card.danger:hover{border-color:rgba(180,35,24,.42)}
.a-card.warn{border-color:rgba(209,154,43,.22)}
.a-card.warn:hover{border-color:rgba(209,154,43,.42)}

.audit-filters{border:1px solid rgba(15,26,22,.12);border-radius:18px;background:rgba(255,255,255,.78);box-shadow:0 10px 22px rgba(0,0,0,.04);padding:12px 12px}
.audit-filter-box{border:1px solid rgba(15,26,22,.12);border-radius:18px;background:rgba(255,255,255,.60);box-shadow:0 10px 22px rgba(0,0,0,.04);overflow:hidden}
.audit-filter-box > summary{cursor:pointer;list-style:none;padding:12px 14px;font-weight:600;color:rgba(14,21,18,.88);background:rgba(255,255,255,.66)}
.audit-filter-box > summary::-webkit-details-marker{display:none}
.audit-filter-box[open] > summary{border-bottom:1px solid rgba(15,26,22,.10)}
.audit-filters .row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.audit-filters .row .field{min-width:140px}
.audit-filters .row .grow{flex:1;min-width:220px}
.audit-filters .smart{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(15,26,22,.14);background:rgba(255,255,255,.72);border-radius:999px;padding:7px 10px;font-size:12px;color:rgba(14,21,18,.76);cursor:pointer;user-select:none}
.chip.active{border-color:rgba(2,122,72,.34);background:rgba(2,122,72,.10);color:rgba(2,122,72,.92)}

.badge{display:inline-flex;align-items:center;gap:8px;padding:5px 9px;border-radius:999px;border:1px solid rgba(15,26,22,.12);font-size:12px;line-height:1;color:rgba(14,21,18,.78);background:rgba(255,255,255,.70)}
.badge.create{border-color:rgba(2,122,72,.34);background:rgba(2,122,72,.10);color:rgba(2,122,72,.92)}
.badge.update{border-color:rgba(30,106,77,.28);background:rgba(30,106,77,.08);color:rgba(20,74,55,.92)}
.badge.delete{border-color:rgba(180,35,24,.30);background:rgba(180,35,24,.10);color:rgba(180,35,24,.92)}
.badge.login{border-color:rgba(15,26,22,.14);background:rgba(15,26,22,.06);color:rgba(15,26,22,.72)}
.badge.reset{border-color:rgba(209,154,43,.30);background:rgba(209,154,43,.12);color:rgba(120,78,16,.92)}
.badge.perm{border-color:rgba(109,40,217,.28);background:rgba(109,40,217,.10);color:rgba(84,27,184,.92)}

.sev{font-size:11px;border-radius:999px;padding:5px 9px;border:1px solid rgba(15,26,22,.12);background:rgba(255,255,255,.68);color:rgba(14,21,18,.70)}
.sev.low{border-color:rgba(15,26,22,.12)}
.sev.med{border-color:rgba(209,154,43,.28);background:rgba(209,154,43,.10)}
.sev.high{border-color:rgba(180,35,24,.30);background:rgba(180,35,24,.10);color:rgba(180,35,24,.92)}

.pager{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px}
.pager .hint{margin-top:0}

/* Drawer */
.dlg[data-size="drawer"]{padding:0}
.dlg[data-size="drawer"]::backdrop{background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.dlg[data-size="drawer"] .dlg-card{width:min(640px, calc(100vw - 0px));height:100dvh;max-height:100dvh;border-radius:0;border-left:1px solid rgba(255,255,255,.22);margin-left:auto}
.dlg[data-size="drawer"] .dlg-head{padding:14px 14px}
.dlg[data-size="drawer"] .dlg-body{padding:14px 14px}
.dlg[data-size="drawer"] .dlg-actions{padding:12px 14px}

/* Trace line */
[data-role="trace"]{display:block;padding:8px 10px;border:1px dashed rgba(15,26,22,.16);border-radius:14px;background:rgba(255,255,255,.60)}

@media (max-width: 980px){
  .grid .span2,.grid .span4,.grid .span6,.grid .span8{grid-column:span 6}
  .grid .span12{grid-column:span 12}
  .stat{padding:12px}
  .stat-v{font-size:20px}
  .a-card{grid-column:span 6}
}
@media (max-width: 560px){
  .grid .span2,.grid .span4,.grid .span6,.grid .span8,.grid .span12{grid-column:span 12}
  .stat{padding:11px 12px;border-radius:12px}
  .stat-k{font-size:11px}
  .stat-v{font-size:18px;line-height:1.15}
  .stat-h{font-size:11px;line-height:1.3}
  .a-card{grid-column:span 12}
}
.kbd{font-family:var(--mono);font-size:11px;background:rgba(15,26,22,.06);border:1px solid rgba(15,26,22,.12);padding:2px 6px;border-radius:8px}

.help{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:6px;border-radius:999px;border:1px solid rgba(15,26,22,.18);background:rgba(255,255,255,.72);color:rgba(15,26,22,.7);font-family:var(--mono);font-size:12px;line-height:1;cursor:pointer}
.help:hover{background:rgba(209,154,43,.18);border-color:rgba(209,154,43,.35)}
.help-pop{position:fixed;z-index:9999;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.96);border:1px solid rgba(15,26,22,.16);box-shadow:var(--shadow2);color:var(--text);font-size:13px;line-height:1.35;white-space:normal}
.geo-map{width:100%;height:320px;border-radius:14px;border:1px solid rgba(15,26,22,.14);overflow:hidden;background:rgba(15,26,22,.08)}
.geo-map.big{height:420px}
.map-empty{display:flex;align-items:center;justify-content:center;min-height:180px;padding:16px;border:1px dashed rgba(15,26,22,.16);border-radius:14px;color:var(--muted);background:rgba(255,255,255,.52);text-align:center}
.geo-upload-box{display:flex;flex-direction:column;gap:10px;padding:12px;border:1px solid rgba(15,26,22,.12);border-radius:14px;background:rgba(255,255,255,.48)}

.mobile-cards{display:flex;flex-direction:column;gap:10px}
.mobile-card{border:1px solid rgba(15,26,22,.12);border-radius:14px;background:rgba(255,255,255,.74);padding:12px}
.mobile-card.child{background:rgba(255,255,255,.62);margin-left:10px}
.mobile-card.pendente{border-color:rgba(180,35,24,.26);background:rgba(180,35,24,.05)}
.mobile-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}
.mobile-card-title{font-family:var(--serif);font-size:15px;color:rgba(14,21,18,.92)}
.mobile-card-sub{margin-top:4px;font-size:12px;color:var(--muted)}
.mobile-card-actions{display:flex;gap:8px;flex-wrap:wrap}
.mobile-kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px;margin-top:10px}
.mobile-kv > div{display:flex;flex-direction:column;gap:3px;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.56);border:1px solid rgba(15,26,22,.08)}
.mobile-kv span{font-size:11px;color:var(--muted)}
.mobile-kv b{font-size:13px;color:rgba(14,21,18,.90)}
.mobile-empty{padding:14px;border:1px dashed rgba(15,26,22,.16);border-radius:14px;background:rgba(255,255,255,.52);color:var(--muted)}
.row-pendente td{background:rgba(180,35,24,.035)}
.crud-mobile-cards{display:none}

/* Rateio de talhoes (viagem) */
.rateio-card{
  border:1px solid rgba(15,26,22,.12);
  background:rgba(255,255,255,.56);
  border-radius:16px;
  padding:12px;
}
.rateio-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.rateio-title{font-family:var(--serif);font-size:14px;color:rgba(14,21,18,.88)}
.rateio-sub{margin-top:3px;color:var(--muted);font-size:12px;max-width:62ch}
.rateio-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.rateio-actions .mini{display:flex;flex-direction:column;gap:6px}
.rateio-actions .mini .label{margin:0}
.rateio-actions select{padding:8px 10px;border-radius:12px}

.rateio-body{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.rateio-grid{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) 120px 150px 110px;
  gap:10px;
  align-items:center;
}
.rateio-header{margin-top:10px;padding:0 6px 8px;border-bottom:1px solid rgba(15,26,22,.10);color:var(--muted);font-size:12px}
.rateio-item{padding:10px;border-radius:14px;border:1px solid rgba(15,26,22,.10);background:rgba(255,255,255,.72)}
.rateio-item:hover{background:rgba(255,255,255,.78)}
.rateio-item.rateio-focus{border-color:rgba(209,154,43,.65);box-shadow:0 0 0 3px rgba(209,154,43,.18)}
.rateio-table tr.rateio-focus td{
  background:#fff3c4;
}

/* Producao tabs */
.tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.tab{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#f1f5f9;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  font-size:13px;
}
.tab:hover{background:rgba(255,255,255,.10)}
.tab.active{
  background:rgba(209,154,43,.18);
  border-color:rgba(209,154,43,.45);
  color:#fff;
}
.rateio-cell{min-width:0}
.rateio-cell select,.rateio-cell input{width:100%}
.rateio-cell[data-cell="rm"]{display:flex;justify-content:flex-end}
.rateio-cell[data-cell="rm"] .btn{width:100%;justify-content:center}
.rateio-foot{margin-top:10px;display:flex;justify-content:flex-start}

@media (max-width: 720px){
  .rateio-grid{grid-template-columns:1fr 1fr;grid-template-areas:"talhao talhao" "pct kg" "rm rm"}
  .rateio-cell[data-cell="talhao"]{grid-area:talhao}
  .rateio-cell[data-cell="pct"]{grid-area:pct}
  .rateio-cell[data-cell="kg"]{grid-area:kg}
  .rateio-cell[data-cell="rm"]{grid-area:rm;justify-content:stretch}
}

@media (max-width: 920px){
  .shell{grid-template-columns:1fr;padding:12px 12px 14px}
  .topbar{padding:12px}
  .brand{flex:1 1 260px}
  .brand-logo,.brand-video{width:64px;height:64px}
  .brand-sub{font-size:11px}
  .top-actions{flex:1 1 100%;justify-content:flex-start}
  .top-actions-split{flex-direction:column;align-items:stretch}
  .top-actions-group{width:100%;padding:6px;background:rgba(255,255,255,.04)}
  .top-actions-links{justify-content:flex-start}
  .top-actions-admin{justify-content:flex-start}
  .top-actions .btn{min-height:44px;padding:10px 12px;font-size:13px}
  .nav{
    position:fixed;
    top:98px;
    left:12px;
    bottom:12px;
    height:calc(100dvh - 110px);
    width:min(320px, calc(100vw - 24px));
    max-height:none;
    z-index:25;
    transition:transform .18s ease, opacity .18s ease;
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    touch-action:pan-y;
    background:linear-gradient(180deg, rgba(15,26,22,.98), rgba(15,26,22,.94));
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 48px rgba(0,0,0,.32);
  }
  .nav-section{display:block;color:rgba(255,255,255,.68)}
  .nav-item.active::before{display:block}
  .nav-item{color:rgba(255,255,255,.94);background:rgba(255,255,255,.04)}
  .nav-item:hover{background:rgba(255,255,255,.08)}
  .nav-item.active{background:rgba(209,154,43,.22);color:#fff;border-color:rgba(209,154,43,.36)}
  body.nav-collapsed .nav{
    display:block;
    transform:translateX(calc(-100% - 18px));
    opacity:0;
    pointer-events:none;
  }
  body.nav-open::after{
    content:"";
    position:fixed;
    inset:0;
    z-index:24;
    background:rgba(15,26,22,.28);
  }
  .main{min-height:calc(100vh - 110px)}
  .producao-head-actions{width:100%;justify-content:flex-start}
  .producao-head-actions .field{width:min(320px,100%)}
}

/* Dialog forms: prevent tiny compressed fields */
@media (max-width: 980px){
  .dlg .form-grid{gap:10px}
  .dlg .col2{grid-column:span 6}
  .dlg .col3{grid-column:span 6}
  .dlg .col4{grid-column:span 6}
  .dlg .col6{grid-column:span 12}
  .dlg .col8{grid-column:span 12}
  .dlg .col9{grid-column:span 12}
  .dlg .dlg-card{width:min(100vw - 18px, 920px);max-height:calc(100dvh - 18px)}
  .audit-filters .row .field,.audit-filters .row .grow{min-width:0;flex:1 1 calc(50% - 12px)}
}

@media (max-width: 560px){
  .top-actions{gap:8px}
  .top-actions .btn{flex:1 1 auto;min-height:44px;padding:10px 12px;font-size:13px}
  .top-actions-group .btn{flex:1 1 calc(50% - 6px)}
  .brand-logo,.brand-video{width:56px;height:56px}
  .brand-title{font-size:15px;letter-spacing:.12em}
  .brand-sub{display:none}
  .panel-head{padding:14px 14px 10px}
  .panel-body{padding:12px}
  .toolbar{align-items:stretch}
  .toolbar > div,.toolbar > form{width:100%}
  .toolbar-actions{justify-content:stretch}
  .toolbar-actions .btn{width:100%}
  .filters > .field,.filters > *{flex:1 1 100%;min-width:0}
  .audit-actions,.dlg-actions,.dlg-overlay-actions{justify-content:stretch}
  .dlg-actions .btn,.dlg-overlay-actions .btn{width:100%}
  .dlg{margin:0;width:100vw;max-width:100vw;max-height:100dvh;padding:0}
  .dlg .dlg-card{width:100%;max-width:100%;max-height:100dvh;border-radius:0}
  .dlg-head{padding:12px 14px}
  .dlg-body{padding:12px 14px}
  .dlg-actions{padding:10px 14px calc(14px + env(safe-area-inset-bottom, 0px))}
  .dlg .dlg-body > .form-grid{
    padding:12px;
    border:1px solid rgba(15,26,22,.12);
    border-radius:18px;
    background:rgba(255,255,255,.82);
    box-shadow:0 12px 26px rgba(0,0,0,.06);
  }
  .dlg-body .form-grid{display:grid;grid-template-columns:1fr;gap:10px}
  .dlg-body .field{min-width:0}
  .dlg .form-card .form-grid{padding:12px}
  .dlg .form-card .card-body{padding:12px}
  .dlg .card-head,
  .dlg .card-actions,
  .dlg .panel-actions,
  .dlg .rateio-head-right,
  .dlg .contract-pane-head,
  .dlg .upload-row{flex-direction:column;align-items:stretch;justify-content:flex-start}
  .dlg .card-actions .btn,
  .dlg .contract-pane-head .btn,
  .dlg .upload-row .btn,
  .dlg .panel-actions .btn{width:100%}
  .dlg .pill-row{align-items:stretch}
  .dlg .pill-row .pill{width:100%}
  .dlg .geo-upload-box{padding:10px}
  .dlg .table-wrap{border-radius:12px}
  .dlg select,.dlg input,.dlg textarea,.dlg .btn{min-height:44px}
  .dlg .rateio-head-left,
  .dlg .card-actions .mini,
  .dlg .card-actions .mini select,
  .dlg .rateio-cardx select[name="talhao_sort"]{min-width:0;width:100%}
  .dlg .rateio-cardx .rateio-grid,
  .dlg .form-card .rateio-grid{grid-template-columns:1fr}
  .stack-table-wrap{overflow:visible;border:none;background:transparent}
  .stack-table,
  .stack-table thead,
  .stack-table tbody,
  .stack-table tr,
  .stack-table td{display:block;width:100%}
  .stack-table thead{display:none}
  .stack-table tbody{display:flex;flex-direction:column;gap:10px}
  .stack-table tr{padding:12px;border:1px solid rgba(15,26,22,.12);border-radius:16px;background:rgba(255,255,255,.82);box-shadow:0 8px 20px rgba(0,0,0,.05)}
  .stack-table td{padding:0;border:none;margin-top:10px}
  .stack-table td:first-child{margin-top:0}
  .stack-table td::before{content:attr(data-label);display:block;margin-bottom:6px;font-size:11px;color:var(--muted);font-weight:600}
  .stack-table td.actions::before{display:none}
  .stack-table td.actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
  .stack-table td.actions .btn{width:100%}
  .dlg .col3{grid-column:span 12}
  .dlg .col4{grid-column:span 12}
  th.actions,td.actions{position:static;left:auto;box-shadow:none;border-right:none}
  .audit-filters .row .field{flex:1 1 calc(50% - 10px);min-width:0}
  .audit-filters .row .grow,
  .audit-submit-row,
  .audit-quick-range{flex:1 1 100% !important;width:100%}
  .pwd-wrap,.pct-row{flex-wrap:wrap;align-items:stretch}
  .pwd-wrap .pwd-toggle{width:100%}
  .pct-read{min-width:0;text-align:left}
  #tblColheita{min-width:980px}
  #tblResumoTalhao{min-width:860px}
  #tblEntregasDestino{min-width:760px}
  #tblPagMotoristas{min-width:620px}
  #aTable{min-width:980px}

  #tblColheita th:nth-child(5),
  #tblColheita td:nth-child(5),
  #tblColheita th:nth-child(6),
  #tblColheita td:nth-child(6),
  #tblColheita th:nth-child(16),
  #tblColheita td:nth-child(16),
  #tblColheita th:nth-child(17),
  #tblColheita td:nth-child(17),
  #tblColheita th:nth-child(18),
  #tblColheita td:nth-child(18){display:none}

  #tblResumoTalhao th:nth-child(2),
  #tblResumoTalhao td:nth-child(2),
  #tblResumoTalhao th:nth-child(8),
  #tblResumoTalhao td:nth-child(8),
  #tblResumoTalhao th:nth-child(9),
  #tblResumoTalhao td:nth-child(9){display:none}

  #tblEntregasDestino th:nth-child(5),
  #tblEntregasDestino td:nth-child(5){display:none}

  #tblPagMotoristas th:nth-child(4),
  #tblPagMotoristas td:nth-child(4){display:none}

  .audit-quick-range{width:100%;display:flex;gap:10px;flex-wrap:wrap}
  .audit-quick-range .btn{flex:1 1 calc(50% - 6px)}
  .audit-filter-box{border-radius:14px}
  .audit-filters{position:static;z-index:auto;padding:10px}
  .audit-cards{gap:10px}
  .pager{align-items:stretch}
  .pager > div{width:100%}
  .pager select,.pager .btn{width:100%}
  #aTable th:nth-child(5),
  #aTable td:nth-child(5),
  #aTable th:nth-child(8),
  #aTable td:nth-child(8){display:none}
  #rTalCards,#rDesCards,#rPayCards{display:flex !important}
  #tblResumoTalhao,#tblEntregasDestino,#tblPagMotoristas{display:none}

  .tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .tab{justify-content:center;text-align:center}
  #tblProdParticipantes{min-width:620px}
  #tblProdPoliticas{min-width:560px}
  #tblProdAcordos{min-width:620px}
  #tblProdVendas{min-width:760px}
  #tblProdCustos{min-width:680px}
  #tblSaldoParticipantes{min-width:720px}
  #tblSaldoTalhoes{min-width:720px}
  #tblSaldoDestinos{min-width:520px}

  #tblProdParticipantes th:nth-child(3),
  #tblProdParticipantes td:nth-child(3),
  #tblProdVendas th:nth-child(3),
  #tblProdVendas td:nth-child(3),
  #tblProdCustos th:nth-child(2),
  #tblProdCustos td:nth-child(2),
  #tblSaldoParticipantes th:nth-child(2),
  #tblSaldoParticipantes td:nth-child(2),
  #tblSaldoTalhoes th:nth-child(2),
  #tblSaldoTalhoes td:nth-child(2){display:none}
  #colheitaCards,#aCardsList{display:flex !important}
  #tblColheita,#aTable,.audit-desktop-wrap{display:none}
  .crud-desktop-wrap{display:none}
  .crud-mobile-cards{display:flex}
  .mobile-card-actions .btn{width:auto;flex:1 1 calc(50% - 6px)}
  .mobile-kv{grid-template-columns:1fr}
  .users-mobile-cards,.quit-mobile-cards,.area-mobile-cards,.notif-mobile-cards{display:flex !important}
  .users-desktop-wrap,.quit-desktop-wrap,.area-desktop-wrap,.notif-desktop-wrap{display:none !important}
  .contract-split{grid-template-columns:1fr}
  .contract-pane-head{align-items:stretch}
  .contract-pane-head .btn{width:100%}

  /* Colheita: keep Placa + Destino side-by-side */
  .dlg .transport-destino{grid-column:span 6}
}
