:root{
  --af-ink:#2E3B4E;
  --af-bg:#F2ECE0;
  --af-surface:#E3D9C6;
  --af-surface-mineral:#D6C9A8;
  --af-accent:#A66848;
  --af-muted:rgba(46,59,78,.6);
  --af-border:rgba(46,59,78,.22);
  --af-hair:rgba(46,59,78,.13);
  --af-inverse:#F2ECE0;
  --af-font-display:'Tenor Sans',serif;
  --af-font-body:'Outfit',sans-serif;
  --af-font-editorial:'Cormorant Garamond',serif;
  --af-font-mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--af-font-body);background:var(--af-bg);color:var(--af-ink);font-size:14px;min-height:100vh;-webkit-font-smoothing:antialiased}
.serif{font-family:var(--af-font-editorial);font-style:italic;font-weight:300}
.logo,.auth-logo{font-family:var(--af-font-display);color:var(--af-ink);background:none;letter-spacing:.3em;padding-left:.3em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;border-radius:0}
.logo{width:auto;height:auto;font-size:24px}
.auth-logo{width:auto;height:auto;font-size:38px;letter-spacing:.34em;padding-left:.34em;margin:0 auto 14px}
.logo svg,.auth-logo svg{display:none}
.app{max-width:900px;margin:0 auto;padding:1.5rem 1rem 4rem}
/* Header */
.header{display:flex;align-items:center;gap:12px;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:1px solid var(--af-border)}
.header-text h1{font-family:var(--af-font-display);font-size:24px;font-weight:400;color:var(--af-ink);letter-spacing:.14em;text-transform:uppercase;line-height:1.1}
.header-text p{font-size:13px;color:var(--af-muted);margin-top:2px}
/* Steps */
.steps{display:flex;align-items:flex-start;margin-bottom:2rem}
.step{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer}
.step-circle{width:30px;height:30px;border-radius:0;border:1px solid var(--af-border);background:var(--af-bg);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--af-muted);font-family:var(--af-font-mono);transition:all .2s}
.step.active .step-circle{background:var(--af-ink);color:var(--af-inverse);border-color:var(--af-ink)}
.step.done .step-circle{background:var(--af-surface-mineral);color:var(--af-ink);border-color:var(--af-surface-mineral)}
.step-lbl{font-size:11px;color:var(--af-muted);text-align:center;line-height:1.3}
.step.active .step-lbl{color:var(--af-ink);font-weight:500}
.step:not(.active):hover .step-circle{border-color:var(--af-accent);color:var(--af-accent)}
.step:hover .step-lbl{color:var(--af-ink)}
.step:focus-visible{outline:1.5px solid var(--af-accent);outline-offset:3px;border-radius:0}
.step-connector{flex:1;height:1px;background:var(--af-border);margin-top:15px}
/* Cards */
.card{background:var(--af-bg);border:1px solid var(--af-border);border-radius:0;padding:1.5rem;margin-bottom:1rem}
.card-title{font-family:var(--af-font-display);font-size:22px;font-weight:400;margin-bottom:.35rem;color:var(--af-ink);letter-spacing:.14em;text-transform:uppercase;line-height:1.15}
.card-sub{font-size:13px;color:var(--af-muted);margin-bottom:1.25rem}
/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.full{grid-column:1/-1}
label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--af-muted);font-family:var(--af-font-mono)}
input,select,textarea{width:100%;padding:8px 10px;border:1px solid var(--af-border);border-radius:0;font-size:14px;background:var(--af-bg);color:var(--af-ink);font-family:inherit;transition:border-color .15s}
input:focus,select:focus,textarea:focus{outline:1.5px solid var(--af-accent);outline-offset:-2px;border-color:var(--af-accent);box-shadow:none}
textarea{resize:vertical;min-height:70px}
/* Risk chips */
.risk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.risk-chip{display:flex;align-items:center;gap:7px;padding:7px 10px;border:1px solid var(--af-border);border-radius:0;cursor:pointer;font-size:13px;transition:all .15s;user-select:none}
.risk-chip:hover{border-color:var(--af-accent);background:var(--af-surface)}
.risk-chip.on{border-color:var(--af-accent);background:var(--af-surface);color:var(--af-accent)}
.risk-chip input{accent-color:var(--af-accent);width:13px;height:13px;pointer-events:none}
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid var(--af-ink);border-radius:0;font-size:11px;font-weight:500;cursor:pointer;background:transparent;color:var(--af-ink);transition:all .15s;font-family:var(--af-font-body);text-transform:uppercase;letter-spacing:.18em}
.btn:hover{background:var(--af-surface)}
.btn:active{opacity:.9}
.btn-primary{background:var(--af-ink);color:var(--af-inverse);border-color:var(--af-ink)}
.btn-primary:hover{background:var(--af-ink);opacity:.92}
.btn-sm{padding:6px 12px;font-size:10px}
.btn-danger{color:var(--af-accent);border-color:var(--af-accent)}
.btn-danger:hover{background:var(--af-surface)}
.btn-warn{color:var(--af-accent);border-color:var(--af-accent)}
.btn-warn:hover{background:var(--af-surface)}
.actions{display:flex;justify-content:flex-end;gap:8px;margin-top:1.5rem}
/* Posto cards */
.posto-card{border:1px solid var(--af-border);border-radius:0;overflow:hidden;margin-bottom:8px}
.posto-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--af-surface);cursor:pointer}
.posto-head h3{font-size:14px;font-weight:500}
.posto-body{padding:14px;display:none}
.posto-body.open{display:block}
.status-badge{font-size:11px;padding:3px 8px;border-radius:0;font-weight:500}
.sb-pending{background:var(--af-surface-mineral);color:var(--af-accent)}
.sb-ready{background:var(--af-surface);color:var(--af-accent)}
.sb-done{background:var(--af-surface-mineral);color:var(--af-ink)}
/* Upload */
.upload-zone{border:1.5px dashed var(--af-border);border-radius:0;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--af-surface)}
.upload-zone:hover{border-color:var(--af-accent);background:var(--af-surface)}
.upload-zone.has-file{border-color:var(--af-accent);background:var(--af-surface)}
.upload-zone p{font-size:13px;color:var(--af-muted);margin-top:4px}
.upload-zone.has-file p{color:var(--af-accent)}
.video-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.video-list:empty{display:none}
.video-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--af-surface);border:1px solid var(--af-border);border-radius:0;font-size:13px}
.video-item-error{border-color:var(--af-accent);background:var(--af-surface)}
.video-item .video-icon{color:var(--af-accent);font-size:13px}
.video-item .video-name{flex:1;color:var(--af-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.video-status{font-size:11px;color:var(--af-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.btn-remove-video{width:24px;height:24px;border:none;border-radius:0;background:transparent;color:var(--af-accent);cursor:pointer;font-size:18px;line-height:1;padding:0;flex-shrink:0}
.btn-remove-video:hover{background:var(--af-surface)}
.btn-add-video{background:var(--af-surface);border:1.5px dashed var(--af-border);color:var(--af-accent);width:100%;justify-content:center;padding:10px}
.btn-add-video:hover{border-color:var(--af-accent);background:var(--af-surface)}
/* Pipeline phases */
.phase-block{margin-bottom:1.25rem}
.phase-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--af-muted);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.phase-num{width:18px;height:18px;border-radius:0;background:var(--af-border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--af-muted);flex-shrink:0}
.phase-num.done{background:var(--af-ink);color:var(--af-inverse)}
.phase-num.active{background:var(--af-accent);color:var(--af-inverse)}
/* Frame grids */
.frame-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:5px;margin-top:8px}
.fcard{border:1px solid var(--af-border);border-radius:0;overflow:hidden;transition:all .15s}
.fcard.selected{border:2px solid var(--af-accent)}
.fcard.discarded{opacity:.35}
.fcard canvas{display:block;width:100%}
.fcard .fmeta{padding:3px 5px;background:var(--af-surface);font-size:10px;color:var(--af-muted)}
.fcard .fmeta span{display:block;line-height:1.4}
/* Score bars */
.sbar-row{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.sbar-lbl{font-size:11px;color:var(--af-muted);min-width:68px}
.sbar-track{flex:1;height:5px;background:var(--af-border);border-radius:0;overflow:hidden}
.sbar-fill{height:100%;border-radius:0;transition:width .5s}
.sbar-val{font-size:10px;color:var(--af-muted);min-width:24px;text-align:right}
/* Metric grid */
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1.25rem}
.metric{background:var(--af-surface);border-radius:0;padding:10px 12px}
.metric .mv{font-size:22px;font-weight:600;line-height:1.1}
.metric .ml{font-size:11px;color:var(--af-muted);margin-top:2px}
/* Progress */
.prog-wrap{margin:8px 0}
.prog-bar{height:5px;background:var(--af-border);border-radius:0;overflow:hidden}
.prog-fill{height:100%;background:var(--af-accent);border-radius:0;transition:width .3s}
.prog-lbl{font-size:12px;color:var(--af-muted);margin-top:4px}
/* Thinking dots */
.dots span{display:inline-block;width:5px;height:5px;border-radius:0;background:var(--af-accent);animation:bounce 1.2s infinite;margin:0 1px}
.dots span:nth-child(2){animation-delay:.2s}
.dots span:nth-child(3){animation-delay:.4s}
@keyframes bounce{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-5px);opacity:1}}
/* Report */
.risk-alto{background:var(--af-surface);color:var(--af-accent);padding:3px 10px;border-radius:0;font-size:12px;font-weight:600}
.risk-medio{background:var(--af-surface-mineral);color:var(--af-accent);padding:3px 10px;border-radius:0;font-size:12px;font-weight:600}
.risk-baixo{background:var(--af-surface);color:var(--af-accent);padding:3px 10px;border-radius:0;font-size:12px;font-weight:600}
.reco-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.reco-list li{display:flex;gap:8px;font-size:13px;line-height:1.5}
.reco-dot{width:6px;height:6px;border-radius:0;background:var(--af-accent);margin-top:5px;flex-shrink:0}
.divider{height:1px;background:var(--af-border);margin:1.25rem 0}
.method-card{border:1px solid var(--af-border);border-radius:0;padding:13px 15px;margin-bottom:10px}
.method-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}
.obs-text{font-size:13px;color:var(--af-ink);line-height:1.6;background:var(--af-surface);padding:10px 12px;border-radius:0;margin-top:8px}
/* Add posto button */
.add-posto-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;border:1.5px dashed var(--af-border);border-radius:0;background:transparent;color:var(--af-muted);font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}
.add-posto-btn:hover{border-color:var(--af-accent);color:var(--af-accent);background:var(--af-surface)}
/* Method selector */
.method-select-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px;margin-top:6px}
.mchip{display:flex;align-items:flex-start;gap:9px;padding:9px 11px;border:1px solid var(--af-border);border-radius:0;cursor:pointer;transition:all .15s;user-select:none}
.mchip:hover{border-color:var(--af-accent);background:var(--af-surface)}
.mchip.on{border-color:var(--af-accent);background:var(--af-surface)}
.mchip input{accent-color:var(--af-accent);width:13px;height:13px;margin-top:2px;pointer-events:none;flex-shrink:0}
.mchip-name{font-size:13px;font-weight:500;color:var(--af-ink);line-height:1.3}
.mchip.on .mchip-name{color:var(--af-accent)}
.mchip-desc{font-size:11px;color:var(--af-muted);line-height:1.4;margin-top:2px}
.mchip.on .mchip-desc{color:var(--af-accent)}
/* Method expect panel */
.mexpect-wrap{margin-top:10px;background:var(--af-surface);border:1px solid var(--af-border);border-radius:0;padding:10px 13px}
.mexpect-hdr{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--af-accent);margin-bottom:9px;display:flex;align-items:center;gap:6px}
.mexpect-hdr svg{width:13px;height:13px;stroke:var(--af-accent);fill:none;stroke-width:2;flex-shrink:0}
.mexpect-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.mexpect-field{background:var(--af-bg);border:1px solid var(--af-border);border-radius:0;padding:9px 11px}
.mexpect-flabel{font-size:11px;font-weight:600;color:var(--af-accent);margin-bottom:5px}
.mexpect-finput{width:100%;padding:6px 9px;border:1px solid var(--af-border);border-radius:0;font-size:14px;font-weight:600;color:var(--af-accent);background:var(--af-bg);font-family:inherit;text-align:center}
.mexpect-finput:focus{outline:1.5px solid var(--af-accent);outline-offset:-2px;border-color:var(--af-accent);box-shadow:none}
.mexpect-finput::placeholder{color:var(--af-muted);font-weight:400}
.mexpect-flvl{font-size:10px;color:var(--af-accent);margin-top:4px;min-height:13px;line-height:1.3}
/* Selected frames strip */
.sel-strip{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}
.sel-thumb{border-radius:0;overflow:hidden;border:2px solid var(--af-accent);text-align:center}
.sel-thumb canvas{display:block}
.sel-thumb span{display:block;font-size:9px;color:var(--af-ink);padding:2px 3px;background:var(--af-surface-mineral)}
/* Info box */
.info-box{background:var(--af-surface);border-radius:0;padding:10px 12px;font-size:13px;color:var(--af-ink);line-height:1.6;margin-top:8px}
.info-box strong{font-weight:600}
/* Error */
.error-box{background:var(--af-surface);border-radius:0;padding:10px 12px;font-size:13px;color:var(--af-accent);margin-top:8px}
/* ─── LAUDO DOCUMENT (ABNT NBR 14724 / NBR 6022) ─── */
.laudo-doc{font-family:'Times New Roman','Liberation Serif',Times,serif;font-size:12pt;line-height:1.5;color:#000;background:#fff;text-align:justify;hyphens:none;-webkit-hyphens:none}
/* Capa */
.laudo-capa{display:flex;flex-direction:column;justify-content:space-between;align-items:center;text-align:center;min-height:calc(100vh - 220px);padding:24mm 0;page-break-after:always}
.laudo-capa-top{font-size:14pt;font-weight:700;text-transform:uppercase;line-height:1.5;width:100%}
.laudo-capa-mid{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:0 12mm}
.laudo-capa-title{font-size:16pt;font-weight:700;text-transform:uppercase;line-height:1.5;letter-spacing:0;margin:0 0 4pt}
.laudo-capa-sub{font-size:12pt;font-weight:400;line-height:1.5;margin:0 0 36pt;font-style:italic}
.laudo-capa-resp{font-size:12pt;line-height:1.5;margin-top:24pt}
.laudo-capa-resp-label{font-weight:700;text-transform:uppercase;margin-bottom:6pt}
.laudo-capa-local{font-size:12pt;font-weight:700;text-transform:uppercase;line-height:1.5;width:100%}
/* Seção primária — fluxo contínuo a partir do tópico 2; só a capa força quebra de página */
.laudo-sec{margin:0;padding:0}
.laudo-sec + .laudo-sec{margin-top:1.5em}
.laudo-sec-title{font-size:12pt;font-weight:700;text-transform:uppercase;text-align:left;text-indent:0;letter-spacing:0;margin:0 0 1.5em;padding:0;border:none}
.laudo-subsec-title{font-size:12pt;font-weight:700;text-align:left;text-indent:0;margin:1.5em 0 1em}
/* Parágrafo */
.laudo-para{text-align:justify;text-indent:1.25cm;margin:0;font-size:12pt;line-height:1.5}
.laudo-para-noindent{text-indent:0}
/* Identificação (campos rótulo: valor) */
.laudo-field{display:block;font-size:12pt;line-height:1.5;text-indent:0;margin:0}
.laudo-field-lbl{font-weight:700;margin-right:4px}
/* Avaliador (na seção 2) */
.laudo-avaliador{margin-top:1em;padding-top:0;font-size:12pt;line-height:1.5}
.laudo-avaliador-title{font-weight:700;text-transform:uppercase;margin-bottom:.2em}
/* Listas */
.laudo-ul{margin:.5em 0 1em 0;padding-left:1.25cm;list-style:disc outside}
.laudo-ul li{margin:0;padding:0;font-size:12pt;line-height:1.5;text-align:justify;text-indent:0}
.laudo-ul li::marker{content:'• '}
/* Cargo / posto (subseção 8.x) */
.laudo-cargo{margin:1.5em 0 0;padding:0;page-break-inside:auto;break-inside:auto}
.laudo-cargo-header{font-size:12pt;font-weight:700;text-transform:none;background:none;border:none;padding:0;margin:1.5em 0 .8em;text-indent:0;text-align:left}
.laudo-method-title{font-size:12pt;font-weight:700;text-transform:none;text-indent:0;text-align:left;margin:1em 0 .5em}
/* Figura (ABNT NBR 6029: legenda acima, fonte abaixo) */
.laudo-frame-critico{margin:1em 0;text-align:center;page-break-inside:avoid;break-inside:avoid}
.laudo-frame-critico img{max-width:100%;max-height:9cm;display:inline-block;border:none;background:#fff;border-radius:0}
.frame-critico-cap{font-size:10pt;font-style:normal;font-weight:400;line-height:1.0;text-align:center;margin:0 0 .3em;color:#000}
.frame-critico-fonte{font-size:10pt;line-height:1.0;text-align:center;margin:.3em 0 0;color:#000}
/* Tabela (padrão IBGE/ABNT — apenas linhas horizontais) */
.l-table-cap{font-size:10pt;line-height:1.0;text-align:center;margin:1em 0 .3em;color:#000}
.l-table{width:100%;border-collapse:collapse;margin:0 auto;font-size:11pt;line-height:1.2;page-break-inside:avoid;break-inside:avoid}
.l-table th{background:none;font-weight:700;padding:5px 8px;border-top:1.5px solid #000;border-bottom:1px solid #000;border-left:none;border-right:none;text-align:left;text-indent:0}
.l-table td{padding:5px 8px;border:none;text-indent:0;text-align:left;vertical-align:top}
.l-table tr:last-child td{border-bottom:1.5px solid #000}
.l-tr-total td{font-weight:700;border-top:1px solid #000}
.l-tr-nivel td{font-weight:700}
.l-table-fonte{font-size:10pt;line-height:1.0;text-align:center;margin:.3em 0 1em;color:#000}
/* Rodapé de override (mantido em nota de rodapé estética ABNT) */
.override-footnote{font-size:10pt;line-height:1.2;font-style:italic;color:#333;margin:.4em 0 0;text-indent:0;background:none;padding:0;border:none;border-radius:0}
/* Toggle de edição direta (admin) */
.laudo-edit-toggle{font-family:var(--af-font-body);font-size:11px;font-weight:500;text-transform:none;letter-spacing:0;margin-left:14px;color:var(--af-muted);display:inline-flex;align-items:center;gap:5px;vertical-align:middle;user-select:none}
.laudo-edit-toggle input{accent-color:var(--af-accent);width:13px;height:13px;cursor:pointer;margin:0}
.laudo-edit-toggle label{cursor:pointer;font-weight:500}
.laudo-edit-toggle.on{color:var(--af-accent)}
.laudo-edit-restore{margin-left:8px;background:none;border:none;color:var(--af-accent);cursor:pointer;font-size:11px;font-family:inherit;text-decoration:underline;padding:0}
.laudo-edit-restore:hover{color:var(--af-accent)}
.laudo-sec-content.editing{outline:1.5px dashed var(--af-accent);outline-offset:6px;background:var(--af-surface);border-radius:2px;padding:4px}
.laudo-sec-content.has-override{position:relative}
.laudo-sec-content.has-override::before{content:'Texto editado pelo administrador';position:absolute;top:-18px;right:0;font-family:var(--af-font-body);font-size:10px;color:var(--af-accent);background:var(--af-surface);padding:1px 8px;border-radius:0;font-weight:500}
@media print{.laudo-edit-toggle,.laudo-edit-restore{display:none!important}.laudo-sec-content.editing{outline:none!important;background:none!important;padding:0!important}.laudo-sec-content.has-override::before{display:none!important}}
/* Pré-visualização em tela: aparência de página A4 */
@media screen{
  .laudo-doc{max-width:210mm;margin:0 auto;padding:30mm 20mm 20mm 30mm;background:#fff;border:1px solid #e6dfd8;box-shadow:0 1px 4px rgba(0,0,0,.05)}
  .laudo-sec{padding-top:1.5em;border-top:1px dashed #e6dfd8;margin-top:1.5em}
  .laudo-sec:first-of-type{padding-top:0;border-top:none;margin-top:0}
  .laudo-capa{min-height:75vh}
}
@media print{
  .header,.steps,.actions,.report-actions,#pg1,#pg2,#pg3,#pg-home,#pg-clientes,#pg-admin,#laudo-save-banner,#laudo-actions-sticky{display:none!important}
  #pg4{display:block!important;padding:0;margin:0}
  #pg4 .card{border:none!important;padding:0!important;box-shadow:none!important;background:#fff!important;margin:0!important}
  #pg4 .card>div:first-child{display:none!important}
  body,html{background:#fff!important;color:#000!important}
  .laudo-doc{max-width:none;width:auto;margin:0;padding:0;border:none;box-shadow:none}
  .laudo-capa{min-height:calc(297mm - 50mm);padding:0;border:none}
  .laudo-sec{border-top:none;padding-top:0;margin-top:0}
  .laudo-cargo{page-break-inside:auto;break-inside:auto}
  .laudo-frame-critico{page-break-inside:avoid;break-inside:avoid}
  .laudo-frame-critico img{max-height:9cm}
  @page{size:A4;margin:30mm 20mm 20mm 30mm;
    @top-right{content:counter(page);font-family:'Times New Roman',Times,serif;font-size:10pt;color:#000}
  }
  @page :first{@top-right{content:''}}
}
/* ─── AUTH ─── */
.auth-overlay{position:fixed;inset:0;background:var(--af-bg);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow-y:auto}
.auth-card{background:var(--af-bg);border:1px solid var(--af-border);border-radius:0;padding:2rem;width:100%;max-width:380px}
.auth-title{font-family:var(--af-font-display);font-size:30px;font-weight:400;text-align:center;margin-bottom:6px;color:var(--af-ink);letter-spacing:.075em;text-transform:uppercase;line-height:1.1}
.auth-sub{font-size:13px;color:var(--af-muted);text-align:center;margin-bottom:1.5rem;line-height:1.5}
.auth-form .fg{margin-bottom:14px}
.auth-form button[type="submit"]{width:100%;justify-content:center;margin-top:6px}
.auth-error{background:var(--af-surface);color:var(--af-accent);padding:9px 12px;border-radius:0;font-size:13px;margin-bottom:12px;line-height:1.5}
.auth-info{background:var(--af-surface-mineral);color:var(--af-ink);padding:9px 12px;border-radius:0;font-size:13px;margin-bottom:12px;line-height:1.5}
/* Header user badge */
.user-badge{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
.user-badge .uname{font-size:13px;color:var(--af-ink);font-weight:500}
.role-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:0;text-transform:uppercase;letter-spacing:.14em;display:inline-block;font-family:var(--af-font-mono)}
.role-admin{background:var(--af-surface-mineral);color:var(--af-ink)}
.role-user{background:var(--af-surface);color:var(--af-ink)}
.role-tag.tag-2fa-on{background:var(--af-surface-mineral);color:var(--af-ink)}
.role-tag.tag-2fa-off{background:var(--af-surface-mineral);color:var(--af-ink)}
.role-tag.tag-2fa-required{background:var(--af-surface-mineral);color:var(--af-ink)}
/* User list */
.user-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--af-border);border-radius:0;margin-bottom:6px;background:var(--af-surface);gap:10px}
.user-row-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-row-name{font-size:14px;font-weight:500;color:var(--af-ink)}
.user-row-meta{font-size:11px;color:var(--af-muted)}
/* ─── REVIEW MODAL ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(46,59,78,.55);z-index:900;display:flex;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}
/* Frente D: import de postos e editar dados abrem SOBRE o modal-cliente. Todos os
   .modal-overlay sao z-index:900 e o modal-cliente vem depois no DOM, entao sem
   este bump esses dois ficariam ATRAS dele. */
#modal-import-postos,#modal-empresa{z-index:950}
.modal-card{background:var(--af-bg);border-radius:0;padding:1.5rem 1.75rem;width:100%;max-width:560px}
.modal-title{font-family:var(--af-font-display);font-size:22px;font-weight:400;margin-bottom:.35rem;color:var(--af-ink);letter-spacing:.075em;text-transform:uppercase;line-height:1.15}
.modal-sub{font-size:13px;color:var(--af-muted);margin-bottom:1.25rem}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:1.25rem;flex-wrap:wrap}
.diff-card{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:1rem}
.diff-cell{background:var(--af-surface);border-radius:0;padding:10px 12px;text-align:center}
.diff-cell-lbl{font-size:10px;color:var(--af-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.diff-cell-val{font-size:18px;font-weight:600;color:var(--af-ink)}
.diff-cell.expected{background:var(--af-surface-mineral)}
.diff-cell.expected .diff-cell-val{color:var(--af-accent)}
.diff-cell.divergent{background:var(--af-surface-mineral)}
.diff-cell.divergent .diff-cell-val{color:var(--af-accent)}
.diff-warning{background:var(--af-surface-mineral);color:var(--af-ink);padding:9px 12px;border-radius:0;font-size:12px;margin-bottom:1rem;line-height:1.5}
.pending-suggestion{border:1px solid var(--af-border);background:var(--af-surface-mineral);border-radius:0;padding:10px 12px;margin:10px 0;font-size:13px;line-height:1.5;color:var(--af-ink)}
.pending-suggestion .suggestion-title{font-weight:600;color:var(--af-accent);margin-bottom:6px}
.report-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--af-border)}
.status-chip{display:inline-flex;align-items:center;gap:6px;border-radius:0;padding:3px 9px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;background:var(--af-surface);color:var(--af-ink);margin-left:8px;vertical-align:middle;font-family:var(--af-font-mono)}
.status-chip[data-status="RASCUNHO"],.status-chip[data-status="DEVOLVIDO_USUARIO"]{background:var(--af-surface);color:var(--af-ink)}
.status-chip[data-status="EM_ANALISE_IA"],.status-chip[data-status="REVISAO_USUARIO"]{background:var(--af-surface-mineral);color:var(--af-ink)}
.status-chip[data-status="ENVIADO_ADMIN"],.status-chip[data-status="SOLICITOU_DEVOLUCAO"]{background:var(--af-bg);color:var(--af-accent);border:1px solid var(--af-accent)}
.status-chip[data-status="REVISAO_ADMIN"]{background:var(--af-surface-mineral);color:var(--af-ink)}
.status-chip[data-status="FINALIZADO"]{background:var(--af-ink);color:var(--af-inverse)}
/* Edit pencil + override badge */
.review-edit{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:0;background:var(--af-ink);color:var(--af-inverse);border:none;cursor:pointer;margin-left:8px;font-size:11px;vertical-align:middle;padding:0}
.review-edit:hover{background:var(--af-ink);opacity:.92}
.override-badge{display:inline-block;font-size:9px;font-weight:700;padding:2px 7px;border-radius:0;background:var(--af-surface-mineral);color:var(--af-ink);text-transform:uppercase;letter-spacing:.04em;margin-left:6px;vertical-align:middle}
.override-badge.ai{background:var(--af-surface-mineral);color:var(--af-ink)}
.override-footnote{font-size:10pt;color:var(--af-muted);font-style:italic;margin-top:4px;padding:6px 10px;background:var(--af-surface);border-left:3px solid var(--af-accent);border-radius:0}
@media print{
  .review-edit{display:none!important}
}
/* ─── HOME (app launcher) ─── */
.home-hero{margin:1rem 0 2.25rem}
.home-hero-title{font-family:var(--af-font-display);font-size:38px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;line-height:1.05;color:var(--af-ink);margin-bottom:8px}
.home-hero-sub{font-size:15px;color:var(--af-muted);line-height:1.5;max-width:560px}
.home-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--af-muted);margin:0 0 14px 4px;font-family:var(--af-font-mono)}
.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.home-card{display:flex;flex-direction:column;gap:14px;background:var(--af-surface);border:1px solid var(--af-border);border-radius:0;padding:24px;cursor:pointer;transition:border-color .18s;text-align:left;font-family:inherit;color:inherit}
.home-card:hover{border-color:rgba(46,59,78,.5);transform:none}
.home-card:focus-visible{outline:1.5px solid var(--af-accent);border-color:var(--af-accent)}
.home-card-icon{width:44px;height:44px;border-radius:0;background:transparent;color:var(--af-ink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.home-card-icon svg{width:22px;height:22px;stroke:var(--af-ink);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.home-card-title{font-family:var(--af-font-display);font-size:24px;font-weight:400;letter-spacing:.1em;text-transform:uppercase;line-height:1.1;color:var(--af-ink)}
.home-card-desc{font-size:13px;line-height:1.55;color:var(--af-muted)}
.home-card-cta{margin-top:auto;padding-top:6px;font-size:13px;font-weight:500;color:var(--af-ink);display:inline-flex;align-items:center;gap:6px;font-family:var(--af-font-mono);text-transform:uppercase;letter-spacing:.18em}
.home-card-cta::after{content:"→";transition:transform .18s}
.home-card:hover .home-card-cta::after{transform:translateX(3px)}
.logo-button{background:none;border:none;padding:0;display:flex;align-items:center;gap:12px;cursor:pointer;font-family:inherit;text-align:left}
.logo-button:hover .header-text h1{color:var(--af-accent)}
.header-text h1{transition:color .15s}
/* Clientes page */
.client-card{background:var(--af-surface);border:1px solid var(--af-border);border-radius:0;padding:14px 16px;margin-bottom:10px;transition:border-color .15s}
.client-card:hover{border-color:var(--af-accent)}
.admin-relatorio-msg{margin-top:8px;border-left:3px solid var(--af-accent);padding:8px 10px;background:var(--af-surface);color:var(--af-ink);font-size:13px;line-height:1.45}
.client-row{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}
.client-info{flex:1;min-width:0}
.client-name{font-size:14px;font-weight:600;color:var(--af-ink);margin-bottom:3px}
.client-fantasy{font-size:13px;color:var(--af-muted);margin-bottom:6px}
.client-meta{font-size:11px;color:var(--af-muted);display:flex;gap:14px;flex-wrap:wrap}
.client-meta strong{color:var(--af-ink);font-weight:600}
.client-actions{display:flex;gap:6px;flex-wrap:wrap}
.client-row-click{transition:opacity .12s}
.client-row-click:hover{opacity:.78}
.posto-line{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:var(--af-surface);border-radius:0;margin-bottom:6px;font-size:13px}
.posto-line-info{flex:1;min-width:0}
.posto-line-name{font-weight:600;color:var(--af-ink)}
.posto-line-meta{font-size:11px;color:var(--af-muted)}
.posto-line-actions{display:flex;gap:5px;flex-shrink:0}
.search-bar{position:relative}
.search-bar input{padding-left:34px}
.search-bar::before{content:'';position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E3B4E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") center/contain no-repeat}
/* ─── Etapa 4.1 — popup full-screen ─── */
.pop41-overlay{position:fixed;inset:0;background:rgba(46,59,78,.78);display:flex;align-items:center;justify-content:center;z-index:10000;padding:18px}
.pop41-card{background:var(--af-bg);border-radius:0;width:min(1100px,96vw);max-height:92vh;display:flex;flex-direction:column;overflow:hidden}
.pop41-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--af-border)}
.pop41-head strong{font-size:15px}
.pop41-prog{font-size:13px;font-weight:600;color:var(--af-accent)}
.pop41-prog.ok{color:var(--af-ink)}
.pop41-body{display:flex;gap:12px;padding:14px 16px;overflow:auto}
.pop41-postos{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:4px}
.pop41-posto{padding:8px 10px;border-radius:0;font-size:12px;cursor:pointer;border:1px solid var(--af-border)}
.pop41-posto.pronto{background:var(--af-surface-mineral)}
.pop41-posto.pend{background:var(--af-surface);color:var(--af-accent)}
.pop41-posto.ativo{outline:1.5px solid var(--af-accent)}
.pop41-main{flex:1;min-width:0}
.pop41-posto-nome{font-weight:700;font-size:14px;margin-bottom:8px}
.pop41-grupo{margin:10px 0}
.pop41-grupo h4{font-size:12px;color:var(--af-muted);margin:6px 0}
.pop41-tira{display:flex;gap:10px;flex-wrap:wrap}
.pop41-thumb{position:relative;border:3px solid transparent;border-radius:0;cursor:pointer;width:200px}
.pop41-thumb img{width:200px;height:auto;display:block;border-radius:0}
.pop41-thumb.sel{border-color:var(--af-accent)}
.pop41-badge{position:absolute;top:5px;left:5px;background:var(--af-ink);color:var(--af-inverse);font-size:10px;padding:1px 6px;border-radius:0;display:none}
.pop41-thumb.sel .pop41-badge{display:block}
.pop41-thumb.falta{outline:2px dashed var(--af-accent)}
.pop41-dica{font-size:12px;color:var(--af-muted);margin-top:8px}
.pop41-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--af-border)}
.pop41-pend{color:var(--af-accent);font-size:12px}
.pop41-foot .btn[disabled]{opacity:.5;cursor:not-allowed}
/* ─── Editor de rosto (abrirEditorRosto) — ausentes na folha servida ─── */
.sel41-overlay{position:fixed;inset:0;background:rgba(46,59,78,.78);display:flex;align-items:center;justify-content:center;z-index:10001}
.sel41-card{background:var(--af-bg);padding:14px;border-radius:0;max-width:92vw;max-height:92vh;overflow:auto}
.sel41-canvaswrap{position:relative;display:inline-block;cursor:crosshair}
.sel41-canvaswrap canvas{display:block;max-width:86vw;max-height:70vh}
.sel41-acoes{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;align-items:center}
.sel41-pend{color:var(--af-accent);font-size:13px;margin:8px 0}
/* ─── Galeria do laudo (spec critério 9) — ausentes na folha servida ─── */
.laudo-galeria{margin:10px 0 4px}
.laudo-galeria-grid{display:flex;flex-wrap:wrap;gap:8px}
.laudo-galeria-img{max-width:260px;height:auto;border:1px solid var(--af-border)}
@media print{.laudo-galeria-img{max-width:240px}}
.laudo-capa-selo{font-family:'Times New Roman',Times,serif;text-align:center;margin-bottom:18pt;font-size:13pt;letter-spacing:.2em}
.laudo-capa-selo span{display:inline-block;width:36px;height:0;border-top:1px solid #000;vertical-align:middle;margin:0 10px}
.laudo-capa-selo em{display:block;font-style:normal;font-size:9pt;letter-spacing:.32em;margin-top:4pt}

/* ─── UX Etapa 2 (2026-05-20): barra sticky do laudo ─── */
.laudo-actions-sticky{position:sticky;top:0;z-index:50;background:var(--af-bg);border-bottom:1px solid var(--af-border);padding:12px 16px;display:flex;gap:8px;align-items:center;margin-bottom:1rem}
.laudo-actions-sticky .btn[disabled]{opacity:.5;cursor:not-allowed}

/* ─── UX Etapa 2 (2026-05-20): popup do ciclo (modal grande + stepper) ─── */
.modal-card.modal-large{width:85vw;max-width:1200px;height:85vh;max-height:900px;display:flex;flex-direction:column;padding:0}
.modal-card.modal-large .modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--af-border)}
.modal-card.modal-large .modal-header .modal-title{margin:0}
.modal-card.modal-large .modal-close{background:transparent;border:0;font-size:24px;cursor:pointer;color:var(--af-muted);line-height:1}
.modal-stepper{display:flex;gap:0;padding:12px 24px;border-bottom:1px solid var(--af-border);background:var(--af-surface-2,#f5f5f5)}
.modal-stepper .step{flex:1;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--af-muted);padding:6px 10px}
.modal-stepper .step .step-num{display:inline-flex;width:24px;height:24px;border-radius:50%;background:var(--af-border);color:var(--af-bg);align-items:center;justify-content:center;font-weight:700;font-size:12px}
.modal-stepper .step.active{color:var(--af-accent);font-weight:600}
.modal-stepper .step.active .step-num{background:var(--af-accent)}
.modal-stepper .step.done{color:var(--af-fg)}
.modal-stepper .step.done .step-num{background:var(--af-fg);color:var(--af-bg)}
.modal-card.modal-large .modal-body{flex:1;overflow-y:auto;padding:24px}
.modal-card.modal-large .modal-footer{border-top:1px solid var(--af-border);padding:12px 24px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.spinner-large{width:48px;height:48px;border:4px solid var(--af-border);border-top-color:var(--af-accent);border-radius:50%;animation:af-spin 1s linear infinite}
@keyframes af-spin{to{transform:rotate(360deg)}}

/* ──────────── Organizacao do trabalho POR POSTO (spec 2026-05-24) ──────────── */
/* Bloco colapsado dentro do card do posto (sub-etapa 1 do popup do ciclo) */
.posto-org-trabalho{margin:12px 0;border:1px solid var(--af-border);border-radius:0;background:var(--af-bg)}
.posto-org-summary{padding:8px 12px;cursor:pointer;display:flex;gap:10px;align-items:center;user-select:none;list-style:none}
.posto-org-summary::-webkit-details-marker{display:none}
.posto-org-summary::before{content:'▸';color:var(--af-muted);font-size:11px;transition:transform .15s}
.posto-org-trabalho[open] .posto-org-summary::before{transform:rotate(90deg)}
.posto-org-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--af-muted)}
.posto-org-status{font-size:12px}
.posto-org-status-igual{color:var(--af-muted)}
.posto-org-status-custom{color:var(--af-accent);font-weight:600}
.posto-org-body{padding:12px;border-top:1px solid var(--af-border);display:flex;flex-direction:column;gap:8px}
.posto-org-body .fg{margin-bottom:0}
.posto-org-body .fg label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--af-muted);display:block;margin-bottom:4px}
.posto-org-body .fg input{width:100%;padding:6px 8px;border:1px solid var(--af-border);background:var(--af-bg);font-size:13px;font-family:inherit}

/* Bloco "Organizacao do trabalho deste cargo" dentro de cada §8.n do laudo final.
   2026-05-26: estilo "ficha" (dl grid 12px cinza) substituido por paragrafo
   ABNT 12pt preto justificado — agora cada campo e um <p class="laudo-para">
   com label em <strong>, igual a "Postura predominante" do header do posto. */
.laudo-org-posto{margin:0}
@media print{.laudo-org-posto{break-inside:avoid}}

/* Botao "Editar posto" no header §8.n do laudo (#5 fila Amanda, 2026-05-25) */
.btn-editar-posto{margin-left:12px;padding:3px 10px;font-size:11px;font-family:var(--af-font-mono);text-transform:uppercase;letter-spacing:.08em;background:transparent;border:1px solid var(--af-border);color:var(--af-muted);cursor:pointer;border-radius:0;vertical-align:middle;transition:border-color .15s,color .15s}
.btn-editar-posto:hover{border-color:var(--af-accent);color:var(--af-accent)}
.btn-editar-posto:focus-visible{outline:1.5px solid var(--af-accent);outline-offset:2px}
@media print{.no-print,.btn-editar-posto{display:none!important}}

/* Modal destrutivo de confirmacao de edicao profunda */
.modal-edicao-confirma-overlay{position:fixed;inset:0;background:rgba(46,59,78,.5);display:flex;align-items:center;justify-content:center;z-index:9999}
.modal-edicao-confirma-card{background:var(--af-bg);padding:24px;max-width:480px;border:1px solid var(--af-border);border-radius:0;font-family:var(--af-font-body);color:var(--af-ink)}
.modal-edicao-confirma-card h3{margin:0 0 12px;font-family:var(--af-font-display);font-size:18px;font-weight:400;letter-spacing:.14em;text-transform:uppercase}
.modal-edicao-confirma-card p{margin:0 0 12px;font-size:14px;line-height:1.45}
.modal-edicao-confirma-aviso{color:var(--af-accent)}
.modal-edicao-confirma-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* Editor da "Atividade desenvolvida" — IA escreve, humano revisa antes de
 * consolidar (#2 fila Amanda, 2026-05-24). Validacao obrigatoria — laudo MTE. */
.descricao-atividade-bloco{margin:12px 0;padding:12px;background:var(--af-surface);border-left:3px solid var(--af-accent)}
.descricao-atividade-bloco label{display:block;font-weight:600;margin-bottom:6px;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--af-ink)}
.descricao-atividade-bloco label small{font-weight:400;color:var(--af-muted);font-size:11px;text-transform:none;letter-spacing:0;margin-left:6px}
.descricao-atividade-bloco textarea{width:100%;padding:8px;font-family:inherit;font-size:13px;line-height:1.45;border:1px solid var(--af-border);background:var(--af-bg);color:var(--af-ink);resize:vertical;min-height:90px}
.descricao-atividade-bloco textarea:focus{outline:1.5px solid var(--af-accent);outline-offset:1px;border-color:transparent}

/* Hint discreta abaixo de campo de formulario (textarea, input). #2 fila Amanda. */
.form-hint{display:block;color:var(--af-muted);font-size:11px;margin-top:4px;font-style:italic}

/* Revisar este cargo (#4 fila Amanda, 2026-05-25). Botao no header §8.n +
 * modal com argumentacao compartilhada e cards de aprovacao por alvo. */
.btn-revisar-cargo{margin-left:8px;padding:4px 10px;font-size:12px;background:var(--af-bg);border:1px solid var(--af-accent);color:var(--af-accent);cursor:pointer;border-radius:0;font-family:var(--af-font-mono);letter-spacing:.04em}
.btn-revisar-cargo:hover{background:var(--af-accent);color:#fff}

.modal-revisao-cargo-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999}
.modal-revisao-cargo-card{background:var(--af-bg);padding:24px;max-width:680px;width:92%;max-height:90vh;overflow-y:auto;border:1px solid var(--af-border);border-radius:0;font-family:var(--af-font-body)}
.modal-revisao-cargo-card h3{margin:0 0 8px;font-family:var(--af-font-headline,inherit)}
.modal-revisao-cargo-card h4{margin:18px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--af-muted)}
.modal-revisao-cargo-card .revcargo-help{font-size:13px;color:var(--af-muted);margin:0 0 12px}
#revcargo-argumento{width:100%;padding:8px;border:1px solid var(--af-border);background:var(--af-bg);color:var(--af-ink);border-radius:0;font-family:inherit;font-size:13px;line-height:1.45;resize:vertical;min-height:90px}
#revcargo-argumento:focus{outline:1.5px solid var(--af-accent);outline-offset:1px;border-color:transparent}

.revcargo-alvos{display:flex;flex-direction:column;gap:10px}
.revcargo-alvo{padding:10px;border:1px solid var(--af-border);background:var(--af-surface)}
.revcargo-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}
.revcargo-check input[type="checkbox"]{margin:0}
.revcargo-notas{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px;font-size:12px;color:var(--af-muted)}
.revcargo-nota-atual strong{color:var(--af-ink)}
.revcargo-nota-alvo input{width:70px;margin-left:6px;padding:3px 6px;border:1px solid var(--af-border);background:var(--af-bg);font-size:12px;border-radius:0}
.modal-revisao-cargo-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}
.revcargo-status{margin-top:12px;font-size:12px;font-family:var(--af-font-mono)}

.revcargo-cards{display:flex;flex-direction:column;gap:12px;margin:12px 0}
.revcargo-card{padding:12px;border:1px solid var(--af-border);background:var(--af-surface)}
.revcargo-card-titulo{font-weight:600;font-size:13px;margin-bottom:6px;color:var(--af-ink)}
.revcargo-card-status{font-size:12px;color:var(--af-muted);font-family:var(--af-font-mono)}
.revcargo-card-body{font-size:13px;margin-top:6px}
.revcargo-card-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:8px}
.revcargo-num-preview{background:var(--af-bg);padding:8px;border:1px solid var(--af-border)}
.revcargo-num-obs{margin-top:6px;font-size:12px;color:var(--af-muted);font-style:italic}
.revcargo-desc-preview{background:var(--af-bg);padding:10px;border-left:3px solid var(--af-accent)}
.revcargo-desc-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--af-muted);margin-bottom:6px}
.revcargo-desc-text{font-size:13px;line-height:1.45}
