:root{
 --navy:#1f3864; --navy2:#2f5496; --amber:#e8a020; --amber-d:#c9871a;
 --bg:#eef1f5; --card:#ffffff; --ink:#1a2332; --muted:#6b7686;
 --line:#dde3ec; --ok:#2e7d32; --soft:#f4f6f9;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;margin:0}
#app{width:100%;max-width:none;margin:0;min-height:100dvh;height:100dvh;background:var(--bg);display:flex;flex-direction:column;position:relative;overflow:hidden}
header:not(.app-header){background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:14px 16px 12px}
header:not(.app-header) h1{font-size:18px;font-weight:700;letter-spacing:.2px}
header:not(.app-header) p{font-size:11.5px;opacity:.8;margin-top:2px}
.steps{display:flex;background:var(--navy);padding:0 6px 10px}
.step{flex:1;text-align:center;cursor:pointer;padding:6px 2px;position:relative}
.step .dot{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;
 display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin:0 auto 4px;transition:.2s}
.step.active .dot{background:var(--amber);color:#1a2332}
.step.done .dot{background:#fff;color:var(--navy)}
.step span{font-size:10px;color:rgba(255,255,255,.7);display:block}
.step.active span{color:#fff;font-weight:600}
main{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px clamp(12px,2vw,24px) 130px}
.card{background:var(--card);border-radius:14px;padding:15px;margin-bottom:12px;box-shadow:0 1px 3px rgba(20,30,50,.08)}
.card h2{font-size:14px;color:var(--navy);margin-bottom:3px;display:flex;align-items:center;gap:7px}
.card h2 .bar{width:4px;height:15px;background:var(--amber);border-radius:2px}
.card .sub{font-size:11.5px;color:var(--muted);margin-bottom:12px}
label{display:block;font-size:12px;font-weight:600;color:var(--navy);margin:10px 0 4px}
label.first{margin-top:0}
/* Em linhas com 2+ campos lado a lado, o label inicial de cada coluna nunca leva margin-top — assim os campos ficam visualmente alinhados sem depender de class="first" em cada fld(). */
.row > div > label:first-child{margin-top:0}
input,select,textarea{width:100%;padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;
 font-size:15px;font-family:inherit;background:var(--soft);color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--amber);background:#fff}
textarea{resize:vertical;min-height:54px}
.row{display:flex;gap:9px}
.row>div{flex:1}
.hint{font-size:11px;color:var(--muted);margin-top:3px}
.btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px 14px;border-radius:11px;
 border:none;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;width:100%}
.btn-primary{background:var(--amber);color:#1a2332}
.btn-primary:active{background:var(--amber-d)}
.btn-nav{background:var(--navy);color:#fff}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-sm{padding:9px 11px;font-size:12.5px;font-weight:600;width:auto}
.actionbar{position:fixed;left:0;right:0;bottom:0;width:100%;max-width:none;margin:0;background:#fff;
 border-top:1px solid var(--line);padding:9px clamp(12px,2vw,24px);padding-bottom:max(9px,env(safe-area-inset-bottom));box-shadow:0 -3px 12px rgba(20,30,50,.07);z-index:100}
.totbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.totbar .lab{font-size:11px;color:var(--muted);font-weight:600}
.totbar .val{font-size:21px;font-weight:800;color:var(--navy)}
.navbtns{display:flex;gap:9px}
.navbtns .btn{flex:1}
.tipo-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.tipo{border:1.5px solid var(--line);border-radius:11px;padding:12px 10px;text-align:center;cursor:pointer;background:var(--soft)}
.tipo.sel{border-color:var(--amber);background:#fff8ec}
.tipo b{display:block;font-size:13px;color:var(--navy)}
.tipo small{font-size:10.5px;color:var(--muted)}
.info{background:#eef3fb;border-left:3px solid var(--navy2);border-radius:8px;padding:10px 11px;font-size:12px;color:#2c3e57;margin-top:10px}
.info b{color:var(--navy)}
.group{border:1px solid var(--line);border-radius:11px;margin-bottom:9px;overflow:hidden}
.ghead{display:flex;align-items:center;justify-content:space-between;padding:11px 12px;background:var(--soft);cursor:pointer}
.ghead .gname{font-size:12.5px;font-weight:700;color:var(--navy)}
.ghead .gtot{font-size:12px;font-weight:700;color:var(--amber-d)}
.gbody{display:none;padding:4px 0}
.group.open .gbody{display:block}
.item{padding:9px 12px;border-top:1px solid var(--line);display:flex;gap:9px;align-items:flex-start}
.item:first-child{border-top:none}
.chk{width:22px;height:22px;flex:none;margin-top:1px}
.idesc{flex:1;min-width:0}
.idesc .dn{font-size:12.5px;font-weight:600}
.idesc .du{font-size:10.5px;color:var(--muted)}
.iqty{display:flex;gap:6px;margin-top:6px}
.iqty input{padding:7px 8px;font-size:13px;text-align:right}
.iqty .q{min-width:110px;width:110px;font-weight:700}.iqty .u{min-width:110px;width:110px;flex:none}.iqty .p{min-width:110px;width:110px}
.iqty .lt{flex:1;text-align:right;font-size:12.5px;font-weight:700;color:var(--navy);padding-top:8px}
.item.off{opacity:.5}
.fotos{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:10px}
.foto{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--soft)}
.foto img{width:100%;height:110px;object-fit:cover;display:block}
.foto textarea{border:none;border-top:1px solid var(--line);border-radius:0;min-height:40px;font-size:11.5px;background:#fff}
.foto .rm{font-size:11px;color:#c0392b;text-align:center;padding:5px;cursor:pointer;font-weight:600;background:#fff}
.addfoto{border:1.5px dashed var(--amber);border-radius:10px;padding:22px 10px;text-align:center;cursor:pointer;background:#fff8ec;color:var(--amber-d);font-weight:700;font-size:12.5px}
.sumrow{display:flex;justify-content:space-between;padding:8px 0;font-size:13px;border-bottom:1px solid var(--line)}
.sumrow.big{font-size:16px;font-weight:800;color:var(--navy);border-bottom:none;padding-top:12px}
.sumrow .v{font-weight:700}
.bar-line{margin:9px 0}
.bar-line .bl-top{display:flex;justify-content:space-between;font-size:11.5px;margin-bottom:3px}
.bar-track{height:9px;background:var(--soft);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--navy2),var(--amber));border-radius:5px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.pill{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px;background:#eef3fb;color:var(--navy2)}
.tag-auto{background:#e9f5ea;color:var(--ok)}
#printarea{display:none}
@media print{
 body{background:#fff}
 #app{display:none}
 #printarea{display:block;padding:24px;font-size:12px;color:#000;max-width:100%}
 #printarea h1{font-size:19px;color:#1f3864;margin-bottom:2px}
 #printarea h2{font-size:13px;color:#1f3864;margin:16px 0 6px;border-bottom:2px solid #1f3864;padding-bottom:3px}
 #printarea table{width:100%;border-collapse:collapse;margin-bottom:8px}
 #printarea th{background:#1f3864;color:#fff;font-size:10px;padding:5px;text-align:left}
 #printarea td{border:1px solid #ccc;padding:4px 6px;font-size:10.5px}
 #printarea .tot td{font-weight:800;background:#eef3fb}
 #printarea .gtr td{font-weight:700;background:#dce6f2}
 #printarea .pf{display:flex;flex-wrap:wrap;gap:8px}
 #printarea .pf div{width:31%;page-break-inside:avoid;break-inside:avoid;margin-bottom:10px}
 #printarea .pf img{width:100%;max-height:220px;object-fit:cover;border:1px solid #ccc}
 #printarea .pf p{font-size:9px;margin-top:3px}
 #printarea .gm-header{display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid #0050A0;padding-bottom:8px;margin-bottom:14px}
 #printarea .gm-logo{width:110px;height:auto}
 #printarea .gm-empresa{text-align:right}
 #printarea .gm-empresa .razao{font-size:13px;font-weight:700;color:#142864;letter-spacing:.4px}
 #printarea .gm-empresa .cnpj{font-size:9px;color:#0050A0}
 #printarea .gm-empresa .contato{font-size:9px;color:#666}
 #printarea .gm-secao{background:#142864;color:#fff;padding:5px 10px;font-weight:700;font-size:11.5px;margin:14px 0 8px;letter-spacing:.3px}
 #printarea .gm-footer{margin-top:18px;text-align:center;font-size:9px;color:#666;border-top:1px solid #0050A0;padding-top:6px}
}

@keyframes flashRow{
 0%{background:#fff7cc;box-shadow:inset 0 0 0 2px #f59e0b}
 50%{background:#fef3c7;box-shadow:inset 0 0 0 2px #fbbf24}
 100%{background:#fff7cc;box-shadow:inset 0 0 0 2px #f59e0b}
}
@keyframes fadeOut{0%{opacity:0;transform:translateX(-50%) translateY(10px)}10%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1}100%{opacity:0;transform:translateX(-50%) translateY(-10px)}}
/* Fase 3 — Painel / Dashboard */
.dash-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
.dash-kpi{background:linear-gradient(135deg,#f4f6f9,#eef3fb);border:1px solid #dde3ec;border-radius:12px;padding:14px;text-align:center}
.dash-kpi .kpi-val{font-size:22px;font-weight:800;color:#1f3864;line-height:1.2}
.dash-kpi .kpi-lab{font-size:10.5px;color:#6b7686;font-weight:600;margin-top:4px;text-transform:uppercase;letter-spacing:.3px}
.dash-kpi.destaque{background:linear-gradient(135deg,#1f3864,#2f5496);border-color:#1f3864}
.dash-kpi.destaque .kpi-val,.dash-kpi.destaque .kpi-lab{color:#fff}
.dash-kpi.verde .kpi-val{color:#10b981}
.gantt-wrap{overflow-x:auto;margin-top:10px;padding-bottom:4px}
.gantt-head{display:flex;gap:8px;font-size:10px;color:var(--muted);margin-bottom:4px;padding-left:128px}
.gantt-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;font-size:11px}
.gantt-lab{min-width:120px;max-width:120px;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.gantt-track{flex:1;height:24px;background:#eef1f5;border-radius:5px;position:relative;min-width:240px}
.gantt-bar{position:absolute;top:2px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#fff;font-weight:700;overflow:hidden;white-space:nowrap;padding:0 4px;box-shadow:0 1px 2px rgba(0,0,0,.12)}
.crono-table{width:100%;border-collapse:collapse;font-size:11.5px;margin-top:8px}
.crono-table th,.crono-table td{border:1px solid var(--line);padding:6px 8px;text-align:left}
.crono-table th{background:#eef3fb;color:var(--navy);font-size:10.5px}
.crono-table input{padding:6px 8px;font-size:12px;border-radius:6px}
.crono-warn{background:#fff7ed;border:1px solid #fbbf24;border-radius:8px;padding:8px 10px;font-size:11.5px;color:#92400e;margin-top:8px}
.dash-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:640px){.cmp-grid{grid-template-columns:1fr}}
.cmp-col{border:1px solid #dde3ec;border-radius:10px;padding:12px;background:#f4f6f9}
.cmp-col h4{margin:0 0 8px;font-size:13px;color:#1f3864}
.cmp-delta{font-size:12px;font-weight:700;padding:6px 10px;border-radius:8px;text-align:center;margin-top:10px}
.cmp-delta.up{background:#d1fae5;color:#065f46}
.cmp-delta.down{background:#fee2e2;color:#991b1b}
.cmp-delta.eq{background:#eef3fb;color:#6b7686}

/* Ditado por voz — escopo */
.btn-escopo-voz{
  font-size:12px;font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer;
  background:#fff;border:2px solid #f59e0b;color:#92400e;font-family:inherit;
  transition:background .15s,border-color .15s,box-shadow .15s;
}
.btn-escopo-voz:hover{background:#fffbeb;border-color:#d97706}
.btn-escopo-voz.escopo-voz-ativo{
  background:#fef3c7;border-color:#dc2626;color:#991b1b;
  box-shadow:0 0 0 3px rgba(220,38,38,.2);
  animation:escopo-voz-pulse 1.4s ease-in-out infinite;
}
@keyframes escopo-voz-pulse{0%,100%{opacity:1}50%{opacity:.75}}
