/* ============================================================
   NotaFácil — style.css
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  --bg:           #F4F3F0;
  --surface:      #FFFFFF;
  --surface-2:    #F9F8F6;
  --border:       rgba(0,0,0,0.09);
  --border-md:    rgba(0,0,0,0.16);
  --text:         #1A1A18;
  --muted:        #6B6B68;
  --hint:         #A0A09C;
  --accent:       #1D9E75;
  --accent-d:     #0F6E56;
  --accent-bg:    #E1F5EE;
  --accent-text:  #085041;
  --danger:       #E24B4A;
  --danger-bg:    #FCEBEB;
  --danger-text:  #7A1F1F;
  --warn:         #BA7517;
  --warn-bg:      #FAEEDA;
  --warn-text:    #633806;
  --info:         #185FA5;
  --info-bg:      #E6F1FB;
  --info-text:    #0C447C;
  --r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;
  --sans:system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'SF Mono','Fira Code',Consolas,monospace;
  --sidebar:220px;
  --shadow:0 2px 12px rgba(0,0,0,0.07);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.12);
}

body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.55}

/* ── Layout ─────────────────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.main{padding:28px 32px;display:flex;flex-direction:column;gap:20px;min-height:100vh}

/* ── Sidebar ─────────────────────────────────────── */
.sidebar{background:var(--surface);border-right:0.5px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:18px 16px 16px;border-bottom:0.5px solid var(--border)}
.logo-mark{width:32px;height:32px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:700;flex-shrink:0}
.logo-text{font-size:14px;font-weight:600}
.logo-sub{font-size:10px;color:var(--hint);margin-top:1px}
.nav-section{font-size:10px;font-weight:600;color:var(--hint);padding:14px 16px 4px;letter-spacing:.08em;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px;color:var(--muted);cursor:pointer;border-left:2px solid transparent;transition:background .12s,color .12s;user-select:none}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item.active{background:var(--accent-bg);color:var(--accent-d);border-left-color:var(--accent);font-weight:500}
.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.5;transition:opacity .12s}
.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}
.sidebar-footer{margin-top:auto;border-top:0.5px solid var(--border);padding:14px 16px}
.sidebar-user{display:flex;align-items:center;gap:10px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--info-bg);color:var(--info-text);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.user-name{font-size:13px;font-weight:500}
.user-role{font-size:11px;color:var(--hint)}

/* ── Page header ─────────────────────────────────── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-title{font-size:18px;font-weight:600}
.page-sub{font-size:13px;color:var(--muted);margin-top:3px}
.header-actions{display:flex;gap:8px;flex-shrink:0}

/* ── Buttons ─────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;border-radius:var(--r-md);cursor:pointer;transition:background .12s,opacity .12s,transform .08s;border:0.5px solid var(--border-md);font-family:var(--sans);white-space:nowrap;line-height:1}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:var(--surface);color:var(--muted)}
.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-danger{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn:disabled{opacity:.56;cursor:not-allowed;pointer-events:none;box-shadow:none}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-icon{padding:6px;width:30px;height:30px;justify-content:center}

/* ── Cards ───────────────────────────────────────── */
.card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:20px 24px}
.card-title{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:16px;padding-bottom:12px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.04em}

/* ── Metric cards ────────────────────────────────── */
.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.metric{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:16px 20px}
.metric-label{font-size:12px;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.metric-value{font-size:22px;font-weight:600;line-height:1}
.metric-sub{font-size:11px;color:var(--hint);margin-top:6px}
.metric-up{color:var(--accent)}
.metric-down{color:var(--danger)}
.metric-actionable{
  width:100%;appearance:none;background:var(--surface);font:inherit;color:inherit;text-align:left;
  cursor:pointer;display:flex;flex-direction:column;gap:0;transition:border-color .15s,box-shadow .15s,transform .15s,background .15s
}
.metric-actionable:hover{border-color:rgba(29,158,117,.24);box-shadow:var(--shadow);transform:translateY(-1px)}
.metric-actionable:focus-visible{
  outline:none;border-color:rgba(29,158,117,.3);
  box-shadow:0 0 0 3px rgba(29,158,117,.12),var(--shadow)
}
.metric-action-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.metric-action-top .metric-label{margin-bottom:0}
.metric-link-indicator{
  flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-d)
}
.metric-foot{
  margin-top:12px;padding-top:12px;border-top:0.5px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:8px
}
.metric-foot-link{font-size:11px;color:var(--muted)}
.metric-chip{
  display:inline-flex;align-items:center;justify-content:center;padding:4px 9px;border-radius:999px;
  font-size:10px;font-weight:700;letter-spacing:.04em;white-space:nowrap
}
.metric-chip-accent{background:var(--accent-bg);color:var(--accent-text)}
.metric-chip-danger{background:var(--danger-bg);color:var(--danger-text)}
.metric-chip-warn{background:var(--warn-bg);color:var(--warn-text)}
.metric-chip-info{background:var(--info-bg);color:var(--info-text)}

/* ── Grids ───────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}

/* ── Form fields ─────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;font-weight:500;color:var(--muted)}
.field input,.field select,.field textarea{width:100%;padding:8px 11px;font-size:13px;border:0.5px solid var(--border-md);border-radius:var(--r-md);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;font-family:var(--sans)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(29,158,117,.12)}
.field textarea{resize:vertical;min-height:72px;line-height:1.5}
.field-hint{font-size:11px;color:var(--hint);margin-top:3px}

/* ── Search bar ──────────────────────────────────── */
.search-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:200px}
.search-wrap input{padding-left:34px;width:100%}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--hint);pointer-events:none}
.filter-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.filter-group select{padding:7px 10px;font-size:13px;border:0.5px solid var(--border-md);border-radius:var(--r-md);background:var(--surface);color:var(--text);outline:none;font-family:var(--sans);cursor:pointer}

/* ── Autocomplete ────────────────────────────────── */
.autocomplete-wrap{position:relative}
.autocomplete-wrap input{padding-right:32px}
.ac-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--hint);pointer-events:none;font-size:14px}
.dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:0.5px solid var(--border-md);border-radius:var(--r-md);z-index:300;max-height:230px;overflow-y:auto;display:none;box-shadow:var(--shadow)}
.dropdown.open{display:block}
.dd-item{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;cursor:pointer;transition:background .1s;border-bottom:0.5px solid var(--border)}
.dd-item:last-child{border-bottom:none}
.dd-item:hover,.dd-item.focused{background:var(--accent-bg)}
.dd-item-left{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.dd-code{font-size:10px;font-weight:600;color:var(--accent);font-family:var(--mono)}
.dd-name{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dd-meta{font-size:12px;color:var(--muted)}
.dd-price{font-size:12px;color:var(--muted);font-family:var(--mono);flex-shrink:0;margin-left:8px}
mark.dd-hl{background:rgba(29,158,117,.18);color:var(--accent-d);border-radius:2px;padding:0 1px}
.dd-empty{padding:12px;text-align:center;color:var(--hint);font-size:13px}

/* ── Tables ──────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{font-size:11px;font-weight:600;color:var(--hint);text-align:left;padding:0 14px 11px;border-bottom:0.5px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}
td{padding:11px 14px;font-size:13px;border-bottom:0.5px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr.hoverable:hover td{background:var(--bg);cursor:pointer}
.td-mono{font-family:var(--mono)}
.td-muted{color:var(--muted)}
.td-actions{display:flex;gap:4px;justify-content:flex-end}

/* ── Badges / Status ─────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7}
.badge-emitida{background:var(--accent-bg);color:var(--accent-text)}
.badge-cancelada{background:var(--danger-bg);color:var(--danger-text)}
.badge-processando{background:var(--warn-bg);color:var(--warn-text)}
.badge-rejeitada{background:#F1EFE8;color:#5F5E5A}
.badge-rascunho{background:#F1EFE8;color:#5F5E5A}
.badge-ativo{background:var(--accent-bg);color:var(--accent-text)}
.badge-inativo{background:#F1EFE8;color:#888780}

/* ── Toggle ──────────────────────────────────────── */
.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:8px;font-size:13px;color:var(--muted)}
.toggle input{position:absolute;opacity:0;width:0;height:0}
.toggle-track{width:36px;height:20px;background:var(--border-md);border-radius:10px;transition:background .2s;flex-shrink:0}
.toggle input:checked+.toggle-track{background:var(--accent)}
.toggle-track::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked+.toggle-track::after{transform:translateX(16px)}

/* ── Steps ───────────────────────────────────────── */
.steps{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.step{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--hint)}
.step.done{color:var(--accent)}
.step.active{color:var(--text);font-weight:500}
.step-num{width:20px;height:20px;border-radius:50%;border:1px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}
.step.done .step-num{background:var(--accent);border-color:var(--accent);color:#fff}
.step-sep{width:20px;height:1px;background:var(--border-md)}

/* ── Items table (emitir) ────────────────────────── */
.items-table th{font-size:11px;font-weight:600;color:var(--hint);text-align:left;padding:0 12px 10px;border-bottom:0.5px solid var(--border)}
.items-table td{padding:10px 12px;font-size:13px;border-bottom:0.5px solid var(--border);vertical-align:middle}
.item-code{font-size:11px;color:var(--accent);font-family:var(--mono);font-weight:600}
.item-name{font-weight:500}
.item-qty,.item-price{padding:5px 8px;font-size:13px;border:0.5px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);color:var(--text);font-family:var(--sans);outline:none;transition:border-color .15s}
.item-qty:focus,.item-price:focus{border-color:var(--accent)}
.item-qty{width:64px;text-align:center}
.item-price{width:100px;font-family:var(--mono)}
.item-total{font-weight:500;font-family:var(--mono);font-size:13px;text-align:right}
.remove-btn{background:none;border:none;cursor:pointer;color:var(--hint);font-size:18px;padding:2px 6px;border-radius:var(--r-sm);transition:all .1s;line-height:1}
.remove-btn:hover{color:var(--danger);background:var(--danger-bg)}
.add-item-row{display:flex;gap:8px;align-items:flex-end;padding-top:14px;border-top:1px dashed var(--border-md);margin-top:6px;flex-wrap:wrap}
.add-item-row .autocomplete-wrap{flex:1;min-width:200px}
.add-item-row .field label{font-size:12px;font-weight:500;color:var(--muted)}
.add-item-row input{width:100%;padding:8px 10px;font-size:13px;border:0.5px solid var(--border-md);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-family:var(--sans);outline:none;transition:border-color .15s}
.add-item-row input:focus{border-color:var(--accent)}
.empty-items{text-align:center;padding:32px;color:var(--hint);font-size:13px;line-height:1.7}

/* ── Totals ──────────────────────────────────────── */
.totals-box{display:flex;flex-direction:column;gap:9px}
.total-row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}
.total-row.final{font-size:15px;font-weight:600;color:var(--text);padding-top:10px;border-top:0.5px solid var(--border-md);margin-top:4px}
.total-val{font-family:var(--mono)}
.emissao-inline-note{
  margin-bottom:14px;padding:12px 14px;border-radius:var(--r-md);
  background:linear-gradient(135deg,rgba(24,95,165,.08),rgba(255,255,255,.96));
  border:0.5px solid rgba(24,95,165,.16);font-size:12px;color:var(--info-text);line-height:1.6
}
.emissao-address-shell{
  margin-top:18px;padding:18px;border-radius:18px;
  background:linear-gradient(180deg,rgba(24,95,165,.06),rgba(255,255,255,.96));
  border:0.5px solid rgba(24,95,165,.16)
}
.emissao-address-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  flex-wrap:wrap;margin-bottom:14px
}
.emissao-address-title{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--info-text)
}
.emissao-address-sub{
  font-size:12px;color:var(--muted);line-height:1.6;margin-top:4px;max-width:70ch
}
.emissao-address-wide{grid-column:span 2}
.emissao-address-grid{align-items:start}
.emissao-financial-layout{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}
.emissao-financial-card{flex:1;min-width:280px}
.emissao-summary-card{
  width:320px;flex-shrink:0;position:sticky;top:16px;
  background:linear-gradient(180deg,var(--surface),var(--surface-2))
}
.emissao-summary-footnote{
  margin-top:14px;padding-top:14px;border-top:0.5px solid var(--border);
  font-size:11px;color:var(--muted);line-height:1.6
}

/* ── Chart ───────────────────────────────────────── */
.dashboard-section-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-bottom:16px;padding-bottom:14px;border-bottom:0.5px solid var(--border)
}
.dashboard-section-head-tight{margin-bottom:14px}
.dashboard-section-title{
  font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em
}
.dashboard-section-sub{font-size:12px;color:var(--muted);line-height:1.6;margin-top:4px;max-width:52ch}
.chart-wrap{margin-top:8px}
.chart-bars{
  display:flex;align-items:stretch;gap:10px;height:156px;padding:14px 0 24px;position:relative;
  border-bottom:0.5px solid var(--border);
  background:
    linear-gradient(to top, rgba(29,158,117,.06), rgba(29,158,117,0)),
    repeating-linear-gradient(to top, transparent 0, transparent 37px, rgba(0,0,0,.05) 37px, rgba(0,0,0,.05) 38px)
}
.chart-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:6px;position:relative;height:100%}
.chart-bar{
  width:100%;background:linear-gradient(180deg,var(--accent),var(--accent-d));
  border-radius:var(--r-sm) var(--r-sm) 0 0;transition:height .3s,filter .2s;position:relative;cursor:default;min-height:0
}
.chart-bar:hover{background:var(--accent)}
.chart-bar.current{filter:saturate(1.05);box-shadow:0 0 0 1px rgba(15,110,86,.14),0 8px 18px rgba(15,110,86,.16)}
.chart-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--text);color:#fff;font-size:11px;padding:4px 8px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;z-index:10}
.chart-bar:hover .chart-tooltip{display:block}
.chart-label{position:absolute;bottom:-22px;font-size:10px;color:var(--hint);white-space:nowrap}
.status-breakdown{display:flex;flex-direction:column;gap:10px}
.status-breakdown-item{
  width:100%;appearance:none;border:none;background:transparent;text-align:left;cursor:pointer;
  border-radius:var(--r-md);padding:10px 12px;transition:background .12s,transform .12s
}
.status-breakdown-item:hover{background:var(--surface-2);transform:translateY(-1px)}
.status-breakdown-item:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(29,158,117,.12)}
.status-breakdown-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.status-breakdown-count{font-size:12px;color:var(--muted)}
.status-breakdown-track{height:6px;background:var(--bg);border-radius:999px;overflow:hidden}
.status-breakdown-fill{height:100%;border-radius:999px;transition:width .4s}

/* ── Tabs ────────────────────────────────────────── */
.tabs{display:flex;gap:0;border-bottom:0.5px solid var(--border);margin-bottom:20px}
.tab{padding:10px 18px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-0.5px;transition:color .12s}
.tab:hover{color:var(--text)}
.tab.active{color:var(--accent-d);border-bottom-color:var(--accent)}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* ── Modal ───────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:400;display:none;backdrop-filter:blur(2px)}
.overlay.show{display:block}
.modal-box{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.97);background:var(--surface);border-radius:var(--r-xl);width:min(560px,calc(100vw - 32px));max-height:calc(100vh - 64px);overflow-y:auto;z-index:500;display:none;box-shadow:var(--shadow-lg)}
.modal-box.show{display:block;transform:translate(-50%,-50%) scale(1)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}
.modal-title{font-size:16px;font-weight:600}
.modal-close{background:none;border:none;cursor:pointer;color:var(--hint);font-size:20px;padding:2px 6px;border-radius:var(--r-sm);line-height:1;transition:color .1s}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 24px}
.modal-footer{padding:0 24px 20px;display:flex;gap:8px;justify-content:flex-end}

/* ── Toast ───────────────────────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:600}
.toast{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:var(--r-md);font-size:13px;font-weight:500;min-width:240px;box-shadow:var(--shadow);animation:slideUp .2s ease;background:var(--surface);border:0.5px solid var(--border)}
.toast-success{background:var(--accent-bg);border-color:var(--accent);color:var(--accent-text)}
.toast-error{background:var(--danger-bg);border-color:var(--danger);color:var(--danger-text)}
.toast-info{background:var(--info-bg);border-color:var(--info);color:var(--info-text)}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Loading / Empty ─────────────────────────────── */
.loading-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--hint);font-size:14px}
.empty-state{text-align:center;padding:48px 24px}
.empty-icon{font-size:36px;margin-bottom:12px;opacity:.4}
.empty-title{font-size:15px;font-weight:500;margin-bottom:6px}
.empty-sub{font-size:13px;color:var(--muted)}

/* ── Detail view (nota detail) ───────────────────── */
.detail-section{margin-bottom:20px}
.detail-section-title{font-size:11px;font-weight:600;color:var(--hint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px}
.detail-row{display:flex;flex-direction:column;gap:2px}
.detail-label{font-size:11px;color:var(--hint)}
.detail-value{font-size:13px;font-weight:500}
.detail-divider{border:none;border-top:0.5px solid var(--border);margin:16px 0}

/* Detail pages */
.detail-back{margin-bottom:4px}
.detail-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;background:linear-gradient(135deg,var(--surface),var(--surface-2));border:0.5px solid var(--border);border-radius:var(--r-lg);padding:20px 24px}
.detail-hero-main{display:flex;align-items:center;gap:14px;min-width:0}
.detail-avatar{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.detail-avatar-info{background:var(--info-bg);color:var(--info-text)}
.detail-avatar-accent{background:var(--accent-bg);color:var(--accent-text)}
.detail-avatar-warn{background:var(--warn-bg);color:var(--warn-text)}
.detail-eyebrow{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--hint);margin-bottom:4px}
.detail-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.detail-title{font-size:24px;font-weight:600;line-height:1.15}
.detail-subline{font-size:13px;color:var(--muted);margin-top:6px}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.detail-layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.95fr);gap:20px;align-items:start}
.detail-column{display:flex;flex-direction:column;gap:20px;min-width:0}
.detail-stack{display:flex;flex-direction:column;gap:12px}
.detail-stack-row{display:flex;justify-content:space-between;gap:16px;padding-bottom:12px;border-bottom:0.5px solid var(--border);align-items:flex-start}
.detail-stack-row:last-child{border-bottom:none;padding-bottom:0}
.detail-stack-label{font-size:12px;color:var(--muted)}
.detail-stack-value{font-size:13px;font-weight:500;text-align:right}
.detail-list{display:flex;flex-direction:column;gap:10px}
.detail-list-item{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border:0.5px solid var(--border);border-radius:var(--r-md);background:var(--surface-2)}
.detail-list-main{display:flex;flex-direction:column;gap:3px;min-width:0}
.detail-list-title{font-size:13px;font-weight:600}
.detail-list-sub{font-size:12px;color:var(--muted)}
.detail-list-meta{font-size:11px;color:var(--hint)}
.detail-list-side{font-size:11px;color:var(--hint);white-space:nowrap}
.detail-note-box{margin-top:12px;padding:12px 14px;background:var(--bg);border-radius:var(--r-md);font-size:12px;color:var(--muted);line-height:1.7}
.detail-empty{padding:24px}

/* ── Config form ─────────────────────────────────── */
.note-detail-shell{display:flex;flex-direction:column;gap:20px}
.note-detail-hero{position:relative;overflow:hidden}
.note-detail-hero>*{position:relative;z-index:1}
.note-detail-hero::after{content:'';position:absolute;right:-48px;bottom:-64px;width:220px;height:220px;background:radial-gradient(circle at center, rgba(29,158,117,.16), transparent 68%);pointer-events:none}
.note-detail-hero-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;width:100%;margin-top:4px}
.note-detail-meta-card{padding:14px 16px;border:0.5px solid rgba(29,158,117,.12);border-radius:16px;background:rgba(255,255,255,.72);backdrop-filter:blur(8px);min-width:0}
.note-detail-meta-label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--hint);margin-bottom:8px}
.note-detail-meta-value{font-size:15px;font-weight:600;line-height:1.2}
.note-detail-meta-sub{font-size:11px;color:var(--muted);margin-top:6px;line-height:1.4}
.note-detail-layout{align-items:start}
.note-detail-note-block{margin-top:16px;padding-top:16px;border-top:0.5px solid var(--border)}
.note-detail-note-title{font-size:11px;font-weight:600;color:var(--hint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.note-party-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.note-party-card{padding:16px;border:0.5px solid var(--border);border-radius:16px;background:linear-gradient(180deg,var(--surface),var(--surface-2))}
.note-party-eyebrow{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--hint);margin-bottom:8px}
.note-party-name{font-size:16px;font-weight:600;line-height:1.25}
.note-party-meta{font-size:12px;color:var(--muted);margin-top:4px}
.note-party-list{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;border-top:0.5px solid var(--border)}
.note-party-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.note-party-row span{font-size:11px;color:var(--hint)}
.note-party-row strong{font-size:12px;font-weight:600;text-align:right}
.note-field-missing{color:var(--warn-text)!important}
.note-warning{margin-top:14px;padding:12px 14px;border-radius:14px;border:0.5px solid transparent}
.note-warning-warn{background:var(--warn-bg);border-color:rgba(186,117,23,.2)}
.note-warning-title{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--warn-text);margin-bottom:6px}
.note-warning-text{font-size:12px;color:var(--text);line-height:1.5}
.note-financial-highlight{padding:18px;border-radius:18px;background:linear-gradient(135deg,var(--accent-bg),rgba(255,255,255,.96));border:0.5px solid rgba(29,158,117,.16);margin-bottom:18px}
.note-financial-highlight-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-text);font-weight:700}
.note-financial-highlight-value{font-size:28px;font-weight:700;line-height:1.05;font-family:var(--mono);margin-top:8px;color:var(--accent-d)}
.note-financial-highlight-sub{font-size:12px;color:var(--muted);margin-top:8px}
.note-panel-hint{margin-bottom:16px;padding:12px 14px;background:var(--bg);border:0.5px solid var(--border);border-radius:14px;font-size:12px;color:var(--muted);line-height:1.6}
.note-action-disabled{color:var(--hint)!important}
.note-action-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.note-action-hint{max-width:220px;font-size:11px;color:var(--hint);line-height:1.45;text-align:right}
.note-timeline{display:flex;flex-direction:column;gap:14px;max-height:320px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}
.note-timeline-item{display:grid;grid-template-columns:14px minmax(0,1fr) auto;gap:12px;align-items:flex-start}
.note-timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);margin-top:7px;box-shadow:0 0 0 4px rgba(29,158,117,.14)}
.note-timeline-content{padding:14px 16px;border:0.5px solid var(--border);border-radius:16px;background:var(--surface-2)}
.note-timeline-title{font-size:13px;font-weight:600}
.note-timeline-sub{font-size:12px;color:var(--muted);margin-top:4px}
.note-timeline-meta{font-size:11px;color:var(--hint);margin-top:6px;line-height:1.4}
.note-timeline-side{font-size:11px;color:var(--hint);white-space:nowrap;padding-top:6px}
.note-log-list{display:flex;flex-direction:column;gap:12px;max-height:360px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}
.note-log-list::-webkit-scrollbar,.note-timeline::-webkit-scrollbar{width:4px}
.note-log-list::-webkit-scrollbar-thumb,.note-timeline::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}
.note-log-list::-webkit-scrollbar-track,.note-timeline::-webkit-scrollbar-track{background:transparent}
.note-log-item{padding:14px 16px;border:0.5px solid var(--border);border-radius:16px;background:var(--surface-2)}
.note-log-item-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.note-log-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.note-log-badge-ok{background:var(--accent-bg);color:var(--accent-text)}
.note-log-badge-warning{background:var(--warn-bg);color:var(--warn-text)}
.note-log-badge-error{background:var(--danger-bg);color:var(--danger-text)}
.note-log-badge-info{background:var(--info-bg);color:var(--info-text)}
.note-log-time{font-size:11px;color:var(--hint)}
.note-log-message{font-size:13px;color:var(--text);line-height:1.6}

.customer-detail-shell{display:flex;flex-direction:column;gap:20px}
.customer-detail-hero{position:relative;overflow:hidden}
.customer-detail-hero>*{position:relative;z-index:1}
.customer-detail-hero::after{content:'';position:absolute;left:-52px;top:-64px;width:220px;height:220px;background:radial-gradient(circle at center, rgba(24,95,165,.14), transparent 68%);pointer-events:none}
.customer-detail-hero-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;width:100%;margin-top:4px}
.customer-detail-meta-card{padding:14px 16px;border:0.5px solid rgba(24,95,165,.12);border-radius:16px;background:rgba(255,255,255,.72);backdrop-filter:blur(8px);min-width:0}
.customer-detail-meta-label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--hint);margin-bottom:8px}
.customer-detail-meta-value{font-size:15px;font-weight:600;line-height:1.2}
.customer-detail-meta-sub{font-size:11px;color:var(--muted);margin-top:6px;line-height:1.4}

.config-section{margin-bottom:28px}
.config-section-title{font-size:13px;font-weight:600;margin-bottom:14px;color:var(--text)}
.config-note{font-size:12px;color:var(--muted);padding:10px 14px;background:var(--info-bg);border-radius:var(--r-md);border:0.5px solid rgba(24,95,165,.2);margin-bottom:16px}
.logo-upload{border:1px dashed var(--border-md);border-radius:var(--r-md);padding:28px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.logo-upload:hover{border-color:var(--accent);background:var(--accent-bg)}
.logo-upload-icon{font-size:24px;margin-bottom:8px;opacity:.4}
.logo-upload-text{font-size:13px;color:var(--muted)}
.logo-upload-sub{font-size:11px;color:var(--hint);margin-top:4px}

.doc-type-badge,.doc-readiness,.document-family-pill,.document-meta-pill{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;
  letter-spacing:.02em;white-space:nowrap;border:0.5px solid transparent
}
.doc-type-badge-compact,.doc-readiness-compact{padding:3px 8px;font-size:10px}
.doc-type-badge-accent,.document-family-pill-accent{background:var(--accent-bg);color:var(--accent-text)}
.doc-type-badge-info,.document-family-pill-info{background:var(--info-bg);color:var(--info-text)}
.doc-type-badge-warn,.document-family-pill-warn{background:var(--warn-bg);color:var(--warn-text)}
.doc-type-badge-danger,.document-family-pill-danger{background:var(--danger-bg);color:var(--danger-text)}
.doc-readiness-pronto{background:var(--accent-bg);color:var(--accent-text)}
.doc-readiness-pendente{background:var(--warn-bg);color:var(--warn-text)}
.doc-readiness-indisponivel{background:#F1EFE8;color:#5F5E5A}
.document-table-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.document-table-number{font-size:12px;color:var(--muted)}
.emission-hub-shell{
  display:flex;flex-direction:column;gap:18px
}
.emission-hub-tabs{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px
}
.emission-hub-tab{
  appearance:none;border:none;text-align:left;cursor:pointer;
  display:flex;flex-direction:column;gap:8px;padding:16px 18px;
  border-radius:18px;background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border:0.5px solid var(--border);box-shadow:var(--shadow);
  transition:transform .12s,box-shadow .12s,border-color .12s,background .12s;
  color:var(--text)
}
.emission-hub-tab:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.emission-hub-tab strong{font-size:15px;line-height:1.2}
.emission-hub-tab span:last-child{font-size:12px;color:var(--muted);line-height:1.45}
.emission-hub-tab.active{
  border-color:rgba(29,158,117,.28);
  background:
    radial-gradient(circle at top left, rgba(29,158,117,.14), transparent 50%),
    linear-gradient(180deg,var(--surface),var(--surface-2));
  box-shadow:var(--shadow-lg)
}
.emission-hub-panel{
  border:0.5px solid var(--border);border-radius:24px;padding:22px;
  background:
    radial-gradient(circle at top right, rgba(24,95,165,.06), transparent 28%),
    linear-gradient(180deg,var(--surface),var(--surface-2));
  box-shadow:var(--shadow)
}
.emission-hub-family{gap:18px}
.emission-hub-family-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap
}
.emission-hub-family-copy{display:flex;flex-direction:column;gap:10px;min-width:0;flex:1}
.emission-hub-family-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.emission-hub-family-title-row h2{font-size:28px;line-height:1.02;font-weight:700}
.emission-hub-family-description{
  font-size:14px;color:var(--muted);line-height:1.7;max-width:62ch
}
.emission-hub-family-stats{
  display:grid;grid-template-columns:repeat(3,minmax(124px,1fr));gap:10px;min-width:min(100%,420px)
}
.emission-hub-family-stat{
  padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.78);
  border:0.5px solid var(--border);font-size:12px;color:var(--muted)
}
.emission-hub-family-stat span{
  display:block;font-size:24px;line-height:1;font-weight:700;color:var(--text);margin-bottom:8px
}
.emission-hub-family-stat-muted span{color:#6E6A5E}
.emission-intro{
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(240px,.8fr);gap:20px;
  padding:24px;border-radius:var(--r-xl);
  background:
    radial-gradient(circle at top left, rgba(29,158,117,.16), transparent 36%),
    linear-gradient(135deg,var(--surface),var(--surface-2));
  border:0.5px solid var(--border)
}
.emission-intro-kicker{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-d);margin-bottom:8px
}
.emission-intro-copy h2{font-size:28px;line-height:1.08;max-width:18ch;margin-bottom:12px}
.emission-intro-copy p{font-size:14px;color:var(--muted);max-width:58ch}
.emission-intro-aside{display:grid;gap:12px}
.emission-intro-stat{
  background:rgba(255,255,255,.72);border:0.5px solid var(--border);
  border-radius:var(--r-lg);padding:16px 18px;font-size:12px;color:var(--muted)
}
.emission-intro-stat span{
  display:block;font-size:26px;line-height:1;font-weight:700;color:var(--text);margin-bottom:8px
}
.document-family{display:flex;flex-direction:column;gap:14px}
.document-family-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.document-family-kicker{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--hint);margin-bottom:4px
}
.document-family-title{font-size:15px;font-weight:600;color:var(--text)}
.document-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.document-card{
  position:relative;display:flex;flex-direction:column;gap:14px;padding:20px;
  border-radius:20px;background:var(--surface);border:0.5px solid var(--border);
  box-shadow:var(--shadow);cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s
}
.document-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.document-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.document-card-icon{
  width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center
}
.document-card-icon svg{width:26px;height:26px}
.document-card-icon-accent{background:var(--accent-bg);color:var(--accent-text)}
.document-card-icon-info{background:var(--info-bg);color:var(--info-text)}
.document-card-icon-warn{background:var(--warn-bg);color:var(--warn-text)}
.document-card-icon-danger{background:var(--danger-bg);color:var(--danger-text)}
.document-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.document-card-title-row h3{font-size:24px;line-height:1;font-weight:700}
.document-card-subtitle{font-size:13px;font-weight:600;color:var(--text)}
.document-card-text{font-size:13px;color:var(--muted);line-height:1.65}
.document-card-pills,.document-pill-grid{display:flex;gap:8px;flex-wrap:wrap}
.document-meta-pill{background:var(--surface-2);border-color:var(--border);color:var(--muted);font-weight:600}
.document-card-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px}
.document-card-hint{font-size:12px;color:var(--muted);min-height:38px}
.document-card-actions{display:flex;gap:8px;flex-wrap:wrap}
.document-card-pronto{border-color:rgba(29,158,117,.28)}
.document-card-pendente{border-color:rgba(186,117,23,.28)}
.document-card-indisponivel{border-color:rgba(0,0,0,.12)}
.emission-page-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.emission-note-ready{background:var(--accent-bg);border-color:rgba(29,158,117,.2);color:var(--accent-text)}
.emission-note-pending{background:var(--warn-bg);border-color:rgba(186,117,23,.2);color:var(--warn-text)}
.document-long-copy{font-size:13px;color:var(--muted);line-height:1.75}
.document-long-copy + .document-long-copy{margin-top:12px}
.document-checklist{display:flex;flex-direction:column;gap:10px}
.document-checklist-item{
  position:relative;padding-left:18px;font-size:13px;color:var(--text);line-height:1.65
}
.document-checklist-item::before{
  content:'';position:absolute;left:0;top:7px;width:8px;height:8px;border-radius:50%;background:var(--accent)
}

/* ── Tag ─────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;background:var(--bg);border:0.5px solid var(--border-md);color:var(--muted)}

/* ── Nota preview ────────────────────────────────── */
.nota-preview{background:var(--bg);border-radius:var(--r-md);padding:16px;font-size:12px;line-height:1.8}
.nota-preview-header{text-align:center;border-bottom:1px solid var(--border-md);padding-bottom:12px;margin-bottom:12px}
.nota-num{font-size:18px;font-weight:700;color:var(--accent)}

/* ── Responsive ──────────────────────────────────── */
@media(max-width:900px){
  :root{--sidebar:0px}
  .sidebar{display:none}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .emission-intro{grid-template-columns:1fr}
  .emission-hub-tabs{
    display:flex;overflow-x:auto;padding-bottom:4px;scrollbar-width:none
  }
  .emission-hub-tab{min-width:220px;flex:0 0 220px}
  .emission-hub-family-head{flex-direction:column}
  .emission-hub-family-stats{grid-template-columns:repeat(3,minmax(110px,1fr));min-width:0;width:100%}
  .document-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:600px){
  .metrics{grid-template-columns:1fr}
  .main{padding:16px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .emission-hub-panel{padding:18px}
  .emission-hub-family-title-row h2{font-size:24px}
  .emission-hub-family-stats{grid-template-columns:1fr}
  .document-card-grid{grid-template-columns:1fr}
  .emission-intro-copy h2{font-size:24px}
}

/* ── Fase 1: Validação inline ────────────────────────────── */
.field-error {
  font-size: 11px;
  color: var(--danger);
  margin-top: 4px;
  min-height: 16px;
  line-height: 1.4;
}

.input-error {
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 3px rgba(226,75,74,.1) !important;
}

.input-ok {
  border-color: var(--accent) !important;
}

.field input.input-error:focus,
.field input.input-ok:focus {
  box-shadow: 0 0 0 3px rgba(29,158,117,.12) !important;
  border-color: var(--accent) !important;
}

/* ── Fase 1: Tela de login ───────────────────────────────── */
.login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  padding: 24px;
}

.login-card {
  background: var(--surface);
  border: 0.5px solid var(--border);
  border-radius: var(--r-xl);
  padding: 36px 40px;
  width: 100%;
  max-width: 400px;
  box-shadow: var(--shadow);
}

.login-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 28px;
}

.login-logo-mark {
  width: 40px;
  height: 40px;
  background: var(--accent);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  flex-shrink: 0;
}

.login-logo-text {
  font-size: 16px;
  font-weight: 600;
}

.login-logo-sub {
  font-size: 11px;
  color: var(--hint);
  margin-top: 2px;
}

.login-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 20px;
  color: var(--text);
}

.login-eye {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--hint);
  padding: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: color .12s;
}

.login-eye:hover { color: var(--text); }

.login-btn {
  width: 100%;
  justify-content: center;
  padding: 10px;
  font-size: 14px;
  margin-top: 4px;
}

.login-error {
  text-align: center;
  margin-bottom: 12px;
  padding: 8px 12px;
  background: var(--danger-bg);
  border-radius: var(--r-md);
  display: block;
}

.login-error:empty { display: none; }

.login-hint {
  margin-top: 20px;
  padding: 12px;
  background: var(--info-bg);
  border-radius: var(--r-md);
  font-size: 12px;
  color: var(--info-text);
  text-align: center;
  border: 0.5px solid rgba(24,95,165,.2);
}

/* ── Fase 1: Botão logout sidebar ────────────────────────── */
#logout-btn {
  display: flex;
  width: 100%;
  justify-content: center;
  font-size: 12px;
  margin-top: 8px;
  gap: 6px;
}

/* ── Fase 2: Emissão / XML / PDF ──────────────────────────── */
@keyframes spin {
  to { transform: rotate(360deg); }
}

.emissao-log-ok    { color: var(--accent); }
.emissao-log-error { color: var(--danger); }
.emissao-log-info  { color: var(--muted);  }

.xml-block {
  background: var(--bg);
  border-radius: var(--r-md);
  padding: 10px;
  font-size: 10px;
  font-family: var(--mono);
  overflow-x: auto;
  max-height: 160px;
  overflow-y: auto;
  white-space: pre;
  word-break: normal;
  border: 0.5px solid var(--border);
}

/* Indicador de ambiente no rodapé */
.env-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
}
.env-producao    { background: var(--accent-bg); color: var(--accent-text); }
.env-homologacao { background: var(--warn-bg);   color: var(--warn-text);   }

/* ── Fase 3: Mobile topbar e sidebar ─────────────────────── */
.mobile-topbar {
  display: none;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  height: 52px;
  background: var(--surface);
  border-bottom: 0.5px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.hamburger {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text);
  padding: 4px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  transition: background .12s;
}

.hamburger:hover { background: var(--bg); }

.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 199;
}

.sidebar-overlay.show { display: block; }

@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; padding-top: 0; }
  .mobile-topbar { display: flex; }

  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 240px;
    transform: translateX(-100%);
    transition: transform .22s ease;
    z-index: 200;
    box-shadow: var(--shadow-lg);
  }

  .sidebar.mobile-open { transform: translateX(0); }

  .main { padding: 16px; }

  .page-header { flex-direction: column; gap: 12px; }
  .header-actions { width: 100%; justify-content: flex-end; }
  .detail-hero { padding: 18px; }
  .detail-hero-main { width: 100%; }
  .detail-actions { width: 100%; justify-content: flex-start; }
  .detail-layout { grid-template-columns: 1fr; }
  .detail-list-item { flex-direction: column; }
  .customer-detail-hero-meta { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .note-detail-hero-meta { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .note-party-grid { grid-template-columns: 1fr; }
  .note-timeline-item { grid-template-columns: 14px minmax(0, 1fr); }
  .note-timeline-side { grid-column: 2; padding-top: 0; }

  .metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }

  .add-item-row { flex-direction: column; }

  /* Stack fatura + resumo */
  .emissao-financial-layout { flex-direction: column; }
  .emissao-summary-card { width: 100%; position: static; }
  .emissao-address-wide { grid-column: auto; }
}

@media (max-width: 480px) {
  .metrics { grid-template-columns: 1fr; }
  .modal-box { width: calc(100vw - 16px); }
  .login-card { padding: 24px 20px; }
  .tabs { overflow-x: auto; }
  .tab { white-space: nowrap; }
  .detail-title { font-size: 20px; }
  .detail-avatar { width: 48px; height: 48px; border-radius: 14px; }
  .detail-stack-row { flex-direction: column; }
  .detail-stack-value { text-align: left; }
  .customer-detail-hero-meta { grid-template-columns: 1fr; }
  .note-detail-hero-meta { grid-template-columns: 1fr; }
  .note-action-stack { align-items: stretch; }
  .note-action-hint { max-width: none; text-align: left; }
  .note-party-row { flex-direction: column; }
  .note-party-row strong { text-align: left; }
  .note-financial-highlight-value { font-size: 22px; }
}

/* ── Fase 3: Notificações ────────────────────────────────── */
#notif-bell { flex-shrink: 0; }

/* ── Fase 3: Relatórios ──────────────────────────────────── */
.rel-bar-label {
  font-size: 12px;
  color: var(--muted);
  min-width: 140px;
  max-width: 160px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Fase 3: Onboarding ──────────────────────────────────── */
.onboarding-step-done { color: var(--accent); }

/* ── Fase 3: Busca rápida ────────────────────────────────── */
kbd {
  font-family: var(--mono);
  font-size: 10px;
  background: var(--surface);
  border: 0.5px solid var(--border-md);
  border-radius: 4px;
  padding: 3px 7px;
  color: var(--text);
}

/* ── Acessibilidade ──────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}

/* Fase 5: automacao, jobs e PWA */
.phase5-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:20px}
.phase5-toolbar{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-bottom:20px}
.phase5-section{margin-bottom:24px}
.phase5-section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}
.phase5-section-title{font-size:13px;font-weight:600;color:var(--text)}
.phase5-provider-sub{font-size:12px;color:var(--muted);margin-top:2px}
.phase5-list{display:flex;flex-direction:column;gap:10px}
.phase5-card{display:flex;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--surface-2);border:0.5px solid var(--border);border-radius:var(--r-md);align-items:flex-start}
.phase5-card.compact{padding:12px 14px}
.phase5-card-main{display:flex;flex-direction:column;gap:4px;min-width:0}
.phase5-card-title{font-size:13px;font-weight:600;color:var(--text)}
.phase5-card-sub{font-size:12px;color:var(--muted)}
.phase5-card-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--hint)}
.phase5-card-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.phase5-empty{padding:16px;background:var(--bg);border-radius:var(--r-md);font-size:12px;color:var(--muted)}
.phase5-provider{padding:16px;border:0.5px solid var(--border);border-radius:var(--r-md);background:var(--surface-2);margin-bottom:14px}
.phase5-provider-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:12px}
.phase5-table-stack{display:flex;flex-direction:column;gap:4px;min-width:0}
.phase5-table-main{font-size:13px;font-weight:600;color:var(--text)}
.phase5-table-sub{font-size:11px;color:var(--muted)}
.phase5-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.02em;width:max-content}
.phase5-status-pill-ready{background:var(--accent-bg);color:var(--accent-text)}
.phase5-status-pill-pending{background:var(--warn-bg);color:var(--warn-text)}
.phase5-status-pill-neutral{background:var(--surface-2);border:0.5px solid var(--border);color:var(--muted)}
.pwa-install-banner{position:fixed;left:16px;right:16px;bottom:74px;z-index:350;background:linear-gradient(135deg,#0F6E56,#1D9E75);color:#fff;border-radius:14px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:var(--shadow-lg)}
.pwa-install-title{font-size:13px;font-weight:600}
.pwa-install-sub{font-size:11px;opacity:.9;margin-top:3px}
.mobile-bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:320;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-top:0.5px solid var(--border);padding:10px 10px calc(10px + env(safe-area-inset-bottom));grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}
.mobile-bottom-nav button{background:none;border:none;border-radius:10px;padding:9px 6px;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer}
.mobile-bottom-nav button.active,.mobile-bottom-nav button.primary{background:var(--accent-bg);color:var(--accent-d)}

@media (max-width: 900px) {
  .phase5-summary-grid{grid-template-columns:1fr}
  .phase5-card,.phase5-provider-head{flex-direction:column}
  .mobile-bottom-nav{display:grid}
  .main{padding-bottom:96px}
}

/* Skip link */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--accent);
  color: #fff;
  padding: 8px 12px;
  border-radius: 0 0 var(--r-md) 0;
  font-size: 13px;
  font-weight: 500;
  z-index: 9999;
  transition: top .15s;
}

.skip-link:focus { top: 0; }

/* style.css additions */
.badge-processando {
  background: hsl(220 80% 55% / 0.15) !important;
  color: hsl(220 80% 55%) !important;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.badge-pulse {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: hsl(220 80% 55%);
  animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.7); }
}
