/* ═══════════════════════════════════════════════════════════════════
 * cd-screens.css · CSS das telas do redesign V1 (alimentado sprint a sprint)
 * Acompanha admin-dashboard.html. Usa tokens de /design-tokens.css (v2).
 * ═══════════════════════════════════════════════════════════════════ */

/* ─── Helpers compartilhados ─────────────────────────────────────── */
.cd-eyebrow { font-size:10px; letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; font-weight:700; color:var(--muted); }
.cd-h1 { font-size:28px; font-weight:800; color:var(--text-strong); letter-spacing:var(--tracking-tight); margin:4px 0; }
.cd-h2 { font-size:20px; font-weight:700; color:var(--text-strong); letter-spacing:var(--tracking-tight); margin:2px 0 0; }
.cd-mono { font-family:var(--font-mono); }
.cd-panel { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:var(--space-5); }

/* ════════ §4 · AO VIVO — Mission Control ════════════════════════ */
#tab-aovivo .ao-vivo { padding-top:6px; }
.ao-header { display:flex; align-items:flex-start; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-bottom:18px; }
.ao-title-row { display:flex; align-items:center; gap:14px; }
.ao-h1 { font-size:26px; font-weight:800; color:var(--text-strong); letter-spacing:var(--tracking-tight); margin:2px 0 0; }
.ao-h1-sub { font-size:14px; font-weight:500; color:var(--muted); }
.ao-controls { display:flex; align-items:center; gap:14px; font-size:12px; color:var(--muted); }
.ao-live { display:inline-flex; align-items:center; gap:7px; color:var(--data-pos); font-weight:600; }
.ao-live .dotmini { width:7px; height:7px; border-radius:50%; background:var(--dot-live); box-shadow:var(--glow-live); display:inline-block; }

/* pulse bar */
.ao-pulse-bar { display:grid; grid-template-columns:repeat(8,1fr); gap:10px; margin-bottom:18px; }
@media(max-width:1200px){ .ao-pulse-bar{ grid-template-columns:repeat(4,1fr); } }
@media(max-width:560px){ .ao-pulse-bar{ grid-template-columns:repeat(2,1fr); } }
.pulse-stat { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-md); padding:12px 14px; }
.pulse-stat .pulse-label { display:flex; align-items:center; gap:6px; font-size:10px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); font-weight:600; margin-bottom:6px; }
.pulse-stat > div:last-child { display:flex; align-items:flex-end; justify-content:space-between; gap:8px; }
.pulse-stat .pulse-value { font-size:24px; font-weight:700; font-family:var(--font-mono); color:var(--text-strong); line-height:1; letter-spacing:var(--tracking-tight); }
.pulse-stat .pulse-unit { font-size:13px; color:var(--muted); font-weight:500; }

/* barra de telemetria de sistema (rodapé do Ao Vivo) */
.ao-sys-bar { display:flex; flex-wrap:wrap; gap:18px; align-items:center; margin-top:18px; padding:10px 14px; background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius-md); font-size:11px; color:var(--muted); }
.ao-sys-bar strong { color:var(--text-soft); font-weight:700; }
.ao-sys-bar .pos { color:var(--data-pos); } .ao-sys-bar .neg { color:var(--data-neg); }
.ao-sys-bar .sys-right { margin-left:auto; }
.ao-sys-bar .sysdot { width:7px; height:7px; border-radius:50%; display:inline-block; margin-right:2px; }
.ao-sys-bar .sysdot.ok { background:var(--dot-live); } .ao-sys-bar .sysdot.bad { background:var(--dot-error); }

/* grid */
.ao-grid { display:grid; grid-template-columns:1.5fr 1fr; gap:18px; }
@media(max-width:980px){ .ao-grid{ grid-template-columns:1fr; } }
.ao-col-head { margin-bottom:14px; }
.ao-agents { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; }

.agent-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-md); padding:14px; position:relative; transition:border-color var(--dur) var(--ease-out); }
.agent-card[data-status="ativo"] { border-color:rgba(52,211,153,0.30); }
.agent-card[data-status="erro"] { border-color:rgba(239,68,68,0.35); }
.agent-head { display:flex; align-items:center; gap:9px; }
.agent-ico { font-size:17px; }
.agent-name { font-weight:600; font-size:13px; color:var(--text-strong); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.agent-ops { font-family:var(--font-mono); font-size:12px; color:var(--muted-strong); font-weight:700; }
.agent-meta { font-size:11px; color:var(--muted); margin-top:8px; font-family:var(--font-mono); }
.agent-group { font-size:9px; text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin-top:2px; }

/* feed */
.ao-feed { max-height:560px; overflow:auto; }
.feed-row { display:flex; gap:9px; align-items:baseline; padding:8px 2px; border-bottom:1px solid var(--border-soft); font-size:12px; }
.feed-row .feed-time { font-family:var(--font-mono); color:var(--muted); min-width:42px; font-size:11px; }
.feed-row .feed-ico { font-size:13px; }
.feed-row .feed-agent { font-weight:600; color:var(--text-strong); }
.feed-row .feed-act { color:var(--muted); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ao-empty { text-align:center; color:var(--muted); padding:32px 12px; font-size:13px; }

/* ════════ §3 · PAINEL DE BORDO ══════════════════════════════════ */
/* greeting */
#tab-dashboard .dash-greeting { display:flex; align-items:flex-start; justify-content:space-between; gap:24px; margin-bottom:20px; flex-wrap:wrap; }
#tab-dashboard .dash-h1 { font-size:28px; font-weight:800; color:var(--text-strong); letter-spacing:var(--tracking-tight); margin:6px 0 5px; }
#tab-dashboard .dash-status-line { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-soft); flex-wrap:wrap; }
#tab-dashboard .dash-status-line .sep { color:var(--muted); }
#tab-dashboard .dash-greeting-actions { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* KPI cards v2 — restyle do .metric existente (preserva HTML + onclick) */
#tab-dashboard .metrics { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-bottom:24px; }
@media(max-width:1100px){ #tab-dashboard .metrics { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ #tab-dashboard .metrics { grid-template-columns:1fr; } }
#tab-dashboard .metrics .metric { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:18px; position:relative; overflow:hidden; transition:border-color var(--dur) var(--ease-out); }
#tab-dashboard .metrics .metric::before { content:""; position:absolute; left:0; top:16px; bottom:16px; width:2px; background:var(--primary); border-radius:2px; opacity:.55; }
#tab-dashboard .metrics .metric.clickable:hover { border-color:var(--primary-ring); }
#tab-dashboard .metrics .metric .metric-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }
#tab-dashboard .metrics .metric .metric-icon { width:34px; height:34px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; font-size:16px; background:var(--primary-soft); }
#tab-dashboard .metrics .metric .metric-change { font-family:var(--font-mono); font-size:11px; font-weight:700; }
#tab-dashboard .metrics .metric .value { font-family:var(--font-mono); font-size:30px; font-weight:700; color:var(--text-strong); letter-spacing:var(--tracking-tight); line-height:1.05; }
#tab-dashboard .metrics .metric .label { font-size:12px; color:var(--muted); margin-top:4px; font-weight:500; }
/* funil 7d */
#tab-dashboard .dash-funnel-strip { display:flex; gap:14px; }
@media(max-width:600px){ #tab-dashboard .dash-funnel-strip { flex-wrap:wrap; } }
#tab-dashboard .funnel-step { flex:1; min-width:90px; background:var(--bg); border:1px solid var(--border-soft); border-radius:var(--radius-md); padding:14px 16px; display:flex; flex-direction:column; gap:4px; position:relative; }
#tab-dashboard .funnel-step:not(:last-child)::after { content:"→"; position:absolute; right:-10px; top:50%; transform:translateY(-50%); color:var(--border-strong); font-size:16px; z-index:1; }
#tab-dashboard .funnel-step .funnel-val { font-size:22px; font-weight:700; letter-spacing:var(--tracking-tight); }

/* ════════ §5 · CRM FUNIL — kanban ═══════════════════════════════ */
.kanban { display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:12px; }
@media(max-width:1200px){ .kanban { display:flex; overflow-x:auto; padding-bottom:12px; } .kanban .kanban-col { min-width:260px; } }
.kanban-col { background:var(--surface); border:1px solid var(--border-soft); border-radius:var(--radius-md); min-height:420px; display:flex; flex-direction:column; transition:background var(--dur),box-shadow var(--dur); }
.kanban-col.drop-target { background:var(--primary-soft); box-shadow:inset 0 0 0 1px var(--primary-ring); }
.kanban-col-head { padding:10px 12px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:8px; position:sticky; top:0; background:var(--surface); border-radius:var(--radius-md) var(--radius-md) 0 0; }
.kanban-col-title { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--text-strong); }
.kanban-col-dot { width:8px; height:8px; border-radius:2px; flex-shrink:0; }
.kanban-col-count { font-family:var(--font-mono); font-weight:700; color:var(--muted-strong); font-size:11px; }
.kanban-col-body { padding:8px; display:flex; flex-direction:column; gap:8px; flex:1; overflow-y:auto; }
.kanban-col-empty { font-size:11px; color:var(--muted); text-align:center; padding:10px 0; }

.funil-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-sm); padding:10px; cursor:grab; transition:border-color var(--dur),transform var(--dur); }
.funil-card:hover { border-color:var(--border-strong); }
.funil-card:active { cursor:grabbing; }
.funil-card-title { font-size:12px; font-weight:600; color:var(--text-strong); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.funil-card-meta { font-size:10px; color:var(--muted); margin-top:3px; font-family:var(--font-mono); display:flex; flex-wrap:wrap; gap:4px; }
.funil-card-tags { display:flex; flex-wrap:wrap; gap:4px; margin-top:6px; }
.funil-card-tag { font-size:9px; padding:1px 6px; border-radius:var(--radius-xs); background:var(--primary-soft); color:#7aa9ff; font-family:var(--font-mono); }
.funil-card-value { font-family:var(--font-mono); font-size:12px; font-weight:700; color:var(--data-pos); margin-top:6px; }
.funil-terminais { margin-top:14px; display:flex; gap:16px; flex-wrap:wrap; font-size:11px; color:var(--muted); }

/* ════════ §6 · INBOX — polish da sidebar ════════════════════════ */
#tab-inbox .inbox-item.active { border-left:3px solid var(--primary); background:var(--primary-soft); }
#tab-inbox .inbox-item-badge { display:flex; flex-wrap:wrap; gap:4px; align-items:center; }
#tab-inbox .inbox-item-badge .tag { font-family:var(--font-mono); font-size:9px; text-transform:uppercase; letter-spacing:.04em; border-radius:var(--radius-xs); padding:1px 6px; font-weight:700; }
#tab-inbox .inbox-item-badge .tag-ia { background:var(--primary-soft); color:#7aa9ff; }
#tab-inbox .inbox-item-badge .tag-operador { background:var(--accent-soft); color:var(--accent); }
#tab-inbox .inbox-item-name .time { font-family:var(--font-mono); font-size:11px; color:var(--muted); font-weight:500; }

/* ════════ §10 · FINANCEIRO — hero do modelo (estático/honesto) ═══ */
#tab-financeiro .fin-hero { display:grid; grid-template-columns:1.3fr 1fr; gap:20px; max-width:1100px; margin:0 auto 18px; background:var(--card); border:1px solid var(--border); border-radius:var(--radius-xl); padding:24px; }
@media(max-width:860px){ #tab-financeiro .fin-hero { grid-template-columns:1fr; } }
#tab-financeiro .fin-hero-h2 { font-size:26px; font-weight:800; color:var(--text-strong); letter-spacing:var(--tracking-tight); line-height:1.15; margin:6px 0 8px; }
#tab-financeiro .fin-hero-text p { font-size:13px; color:var(--muted); line-height:var(--lh-base); }
#tab-financeiro .fin-hero-model { background:var(--bg); border:1px solid var(--border-soft); border-radius:var(--radius-lg); padding:16px; }
#tab-financeiro .fin-tier { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 0; border-bottom:1px solid var(--border-soft); }
#tab-financeiro .fin-tier strong { font-size:13px; color:var(--text-strong); display:block; }
#tab-financeiro .fin-tier small { font-size:11px; color:var(--muted); }
#tab-financeiro .fin-tier span { font-size:20px; font-weight:700; }
#tab-financeiro .fin-fundador { margin-top:12px; font-size:12px; color:var(--text-soft); background:var(--accent-soft); border-radius:var(--radius-sm); padding:8px 10px; }

/* ════════ §13 · Z-API — gráfico de uptime 30d ═══════════════════ */
.zapi-uptime-bars { display:flex; align-items:flex-end; gap:3px; height:64px; }
.zapi-uptime-bars .zapi-bar { flex:1; min-width:4px; border-radius:2px 2px 0 0; background:var(--data-pos); transition:opacity var(--dur); }
.zapi-uptime-bars .zapi-bar.warn { background:var(--accent); }
.zapi-uptime-bars .zapi-bar.bad { background:var(--data-neg); }
.zapi-uptime-bars .zapi-bar.nodata { background:var(--border-strong); opacity:.5; }

/* ════════ §9 · MEU TRUST — hero + pilares ═══════════════════════ */
#tab-meu-trust .trust-hero { margin-bottom:16px; }
#tab-meu-trust .trust-hero-row { display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
#tab-meu-trust .trust-hero-info { flex:1; min-width:160px; }
#tab-meu-trust .trust-hero-tier { font-size:26px; font-weight:800; letter-spacing:var(--tracking-tight); margin:4px 0 6px; }
#tab-meu-trust .trust-hero-papeis { display:flex; flex-wrap:wrap; gap:4px; }
#tab-meu-trust .trust-hero-score { text-align:right; }
#tab-meu-trust .trust-score-big { font-size:40px; font-weight:700; line-height:1; letter-spacing:var(--tracking-tight); }
#tab-meu-trust .trust-score-of { font-size:13px; color:var(--muted); }
#tab-meu-trust .trust-progress { margin-top:18px; }
#tab-meu-trust .trust-progress-labels { display:flex; justify-content:space-between; font-size:11px; color:var(--muted); margin-bottom:5px; }
#tab-meu-trust .trust-progress-labels strong { color:var(--accent); }
#tab-meu-trust .trust-progress-bar { height:8px; background:var(--border); border-radius:var(--radius-full); overflow:hidden; }
#tab-meu-trust .trust-progress-fill { height:100%; border-radius:var(--radius-full); transition:width .4s var(--ease-out); }
#tab-meu-trust .trust-reqs { font-size:12px; color:var(--muted); margin-top:8px; padding-left:18px; }
#tab-meu-trust .trust-max { margin-top:14px; color:var(--data-pos); font-size:13px; font-weight:600; }
#tab-meu-trust .trust-pilares { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:18px; }
@media(max-width:600px){ #tab-meu-trust .trust-pilares { grid-template-columns:1fr; } }
#tab-meu-trust .pilar-head { display:flex; justify-content:space-between; font-size:12px; color:var(--text-soft); margin-bottom:5px; }
#tab-meu-trust .pilar-head .cd-mono { font-weight:700; }
#tab-meu-trust .pilar-head [data-tone="pos"] { color:var(--data-pos); } #tab-meu-trust .pilar-head [data-tone="warn"] { color:var(--accent); } #tab-meu-trust .pilar-head [data-tone="neg"] { color:var(--data-neg); }
#tab-meu-trust .pilar-head small { color:var(--muted); font-weight:400; }
#tab-meu-trust .pilar-bar { height:6px; background:var(--border); border-radius:var(--radius-full); overflow:hidden; }
#tab-meu-trust .pilar-fill { height:100%; border-radius:var(--radius-full); }
#tab-meu-trust .pilar-fill[data-tone="pos"] { background:var(--data-pos); } #tab-meu-trust .pilar-fill[data-tone="warn"] { background:var(--accent); } #tab-meu-trust .pilar-fill[data-tone="neg"] { background:var(--data-neg); }

/* ════════ §12 · GR — Revisar Documentos (3 colunas, honesto) ════ */
#tab-gr .gr-native { display:grid; grid-template-columns:240px 1fr 300px; gap:14px; align-items:start; }
@media(max-width:1100px){ #tab-gr .gr-native { grid-template-columns:1fr; } }
#tab-gr .gr-fila { max-height:74vh; overflow:auto; }
#tab-gr .gr-fila-head { margin-bottom:10px; }
#tab-gr .gr-fila-item { padding:10px; border-radius:var(--radius-sm); cursor:pointer; border:1px solid transparent; }
#tab-gr .gr-fila-item:hover { background:var(--elevated); }
#tab-gr .gr-fila-item.sel { background:var(--primary-soft); border-color:var(--primary-ring); }
#tab-gr .gr-fila-nome { font-size:13px; font-weight:600; color:var(--text-strong); }
#tab-gr .gr-fila-meta { font-size:10px; color:var(--muted); margin-top:2px; }
#tab-gr .gr-viewer { min-height:300px; display:flex; align-items:center; justify-content:center; }
#tab-gr .gr-empty { color:var(--muted); font-size:13px; text-align:center; padding:30px 12px; }
#tab-gr .gr-icp { display:flex; gap:10px; align-items:flex-start; padding:12px; border-radius:var(--radius-md); margin-top:6px; }
#tab-gr .gr-icp.ok { background:var(--success-soft); border:1px solid var(--success-ring); }
#tab-gr .gr-icp.warn { background:var(--warning-soft); border:1px solid var(--accent-ring); }
#tab-gr .gr-icp-ico { font-size:20px; }
#tab-gr .gr-icp-status { font-weight:700; font-size:13px; color:var(--text-strong); }
#tab-gr .gr-icp-meta { font-size:10px; color:var(--muted); margin-top:2px; }
#tab-gr .gr-ocr { display:flex; flex-direction:column; gap:4px; margin-top:6px; }
#tab-gr .gr-ocr-field { display:flex; justify-content:space-between; gap:8px; font-size:12px; padding:4px 0; border-bottom:1px solid var(--border-soft); }
#tab-gr .gr-ocr-field > span:first-child { color:var(--muted); text-transform:capitalize; }
#tab-gr .gr-ocr-field > span:last-child { color:var(--text-strong); font-weight:600; }
#tab-gr .gr-ocr-empty { font-size:12px; color:var(--muted); margin-top:4px; }
#tab-gr .gr-manual { display:grid; grid-template-columns:1fr 1fr; gap:4px 10px; font-size:12px; color:var(--muted); margin-top:6px; }
#tab-gr .gr-soon { margin-top:6px; font-size:12px; color:var(--muted); display:flex; flex-direction:column; gap:5px; }
#tab-gr .gr-soon-tag { font-size:9px; color:var(--accent); border:1px solid var(--accent-ring); border-radius:var(--radius-xs); padding:1px 5px; margin-right:6px; }
#tab-gr .gr-soon-hint { font-size:10px; opacity:.8; margin-top:2px; }
#tab-gr .gr-actions { display:flex; gap:8px; margin-top:18px; }
#tab-gr .cd-btn-aprovar { flex:1; background:var(--primary); color:#fff; border:none; padding:11px; border-radius:var(--radius-md); font-weight:700; font-size:13px; cursor:pointer; font-family:inherit; }
#tab-gr .cd-btn-rejeitar { background:transparent; color:var(--data-neg); border:1px solid var(--danger-ring); padding:11px 16px; border-radius:var(--radius-md); font-weight:600; font-size:13px; cursor:pointer; font-family:inherit; }

/* ── §3.2 Painel de Bordo · KPI cards (handoff redesign V1) ───────────────── */
#tab-dashboard .kpi-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-bottom: 24px; }
@media (max-width: 1100px) { #tab-dashboard .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { #tab-dashboard .kpi-grid { grid-template-columns: 1fr; } }
#tab-dashboard .kpi-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px; position: relative; overflow: hidden; transition: border-color .15s, transform .15s; }
#tab-dashboard .kpi-card.clickable { cursor: pointer; }
#tab-dashboard .kpi-card.clickable:hover { border-color: var(--primary-ring); transform: translateY(-1px); }
#tab-dashboard .kpi-accent-strip { position: absolute; left: 0; top: 16px; bottom: 16px; width: 2px; background: var(--primary); border-radius: 2px; opacity: 0.55; }
#tab-dashboard .kpi-card[data-accent="accent"] .kpi-accent-strip { background: var(--accent); }
#tab-dashboard .kpi-card[data-accent="success"] .kpi-accent-strip { background: var(--data-pos); }
#tab-dashboard .kpi-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
#tab-dashboard .kpi-icon { width: 34px; height: 34px; border-radius: var(--radius-md); background: var(--primary-soft); color: var(--primary); display: flex; align-items: center; justify-content: center; font-size: 16px; }
#tab-dashboard .kpi-card[data-accent="accent"] .kpi-icon { background: var(--accent-soft, rgba(245,158,11,0.14)); color: var(--accent); }
#tab-dashboard .kpi-card[data-accent="success"] .kpi-icon { background: rgba(52,211,153,0.12); color: var(--data-pos); }
#tab-dashboard .kpi-delta { font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: var(--radius-sm); font-family: var(--font-mono); color: var(--muted); }
#tab-dashboard .kpi-delta[data-tone="pos"] { color: var(--data-pos); background: rgba(52,211,153,0.10); }
#tab-dashboard .kpi-delta[data-tone="neg"] { color: var(--data-neg); background: rgba(248,113,113,0.10); }
#tab-dashboard .kpi-value { font-size: 30px; font-weight: 700; color: var(--text-strong); line-height: 1.05; letter-spacing: -0.02em; }
#tab-dashboard .kpi-value.mono { font-family: var(--font-mono); }
#tab-dashboard .kpi-label { font-size: 12px; color: var(--muted); margin-top: 4px; font-weight: 500; }
#tab-dashboard .kpi-sub { font-size: 11px; color: var(--muted); margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border-soft); }
#tab-dashboard .kpi-card.active-filter { border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary); }

/* ════════ §11 · CONFIG — sidebar 230px + área de detalhe ════════ */
#tab-config .config-layout { display: flex; gap: 22px; max-width: 1100px; margin: 0 auto; align-items: flex-start; }
/* G2 (AUDITORIA §2 · OK do Flavio): sidebar de seções REMOVIDO — navegação pela faixa
   de comandos (goCfg rola/revela a seção); conteúdo full-width. .config-nav fica oculto. */
#tab-config .config-nav { display: none !important; }
#tab-config .config-nav .eyebrow { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); padding: 8px 12px 4px; }
#tab-config .config-nav-item { display: flex; align-items: center; gap: 9px; padding: 9px 12px; border-radius: var(--radius-sm); cursor: pointer; background: transparent; border: none; border-left: 2px solid transparent; text-align: left; width: 100%; font-family: inherit; color: var(--text-soft); font-size: 12px; font-weight: 600; transition: background var(--dur), color var(--dur); }
#tab-config .config-nav-item:hover { background: var(--surface); }
#tab-config .config-nav-item .cni-icon { font-size: 14px; color: var(--muted-strong); flex-shrink: 0; }
#tab-config .config-nav-item.active { background: var(--primary-soft); border-left-color: var(--primary); color: var(--text-strong); }
#tab-config .config-nav-item.active .cni-icon { color: var(--primary); }
#tab-config .config-nav-item.config-nav-danger { color: var(--danger); }
#tab-config .config-nav-item.config-nav-danger.active { border-left-color: var(--danger); }
#tab-config .config-nav-item.config-nav-danger .cni-icon { color: var(--danger); }
#tab-config .config-nav-sep { border: none; border-top: 1px solid var(--border); margin: 10px 8px; }
#tab-config .config-audit-log { margin-top: 14px; padding: 12px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); font-size: 11px; color: var(--muted); line-height: 1.5; }
#tab-config .config-audit-log strong { color: var(--text-soft); display: block; margin-bottom: 4px; }
#tab-config .config-audit-log a { color: var(--primary); text-decoration: none; display: inline-block; margin-top: 6px; }
#tab-config .config-content { flex: 1; min-width: 0; max-width: 100%; }
#tab-config .config-content .panel { scroll-margin-top: 16px; }
@media (max-width: 900px) {
  #tab-config .config-layout { flex-direction: column; }
  #tab-config .config-nav { display: none; }
  #tab-config .config-content { max-width: 100%; }
}

/* ════════ §7.3 · FRETES — barra de ações: kebab (⋯) ═════════════ */
.fretes-kebab-wrap { position: relative; display: inline-flex; }
.fretes-kebab-menu { display: none; position: absolute; right: 0; top: calc(100% + 4px); z-index: 40; background: var(--elevated, var(--card)); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 4px; min-width: 180px; box-shadow: 0 10px 28px rgba(0,0,0,0.45); }
.fretes-kebab-menu.open { display: block; }
.fretes-kebab-menu button { display: block; width: 100%; text-align: left; background: transparent; border: none; color: var(--text-soft); font-family: inherit; font-size: 13px; padding: 8px 12px; border-radius: var(--radius-sm); cursor: pointer; white-space: nowrap; }
.fretes-kebab-menu button:hover { background: var(--surface); color: var(--text-strong); }

/* ════════ §7.1 · FRETES — form como hero full-width (3 colunas) ══ */
#tab-fretes .main-grid { display: block; }
#tab-fretes #fretes-form-panel { margin-bottom: 20px; }
#tab-fretes .fretes-form-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px 22px; margin: 4px 0; }
#tab-fretes .fretes-col { min-width: 0; }
#tab-fretes .fretes-col > div[style*="border-top"]:first-child { border-top: none !important; padding-top: 0 !important; margin-top: 6px !important; }
@media (max-width: 980px) { #tab-fretes .fretes-form-grid { grid-template-columns: 1fr; } }

/* ════════ §7.1b · FRETES — form hero RECOLHÍVEL no desktop (lista é a prioridade) ══
   Decisão de design (Opção 3): no desktop o form começa recolhido — só o hero do
   Smart Paste fica visível (~140px) e a lista aparece sem rolar. O #form-frete (campos
   manuais + botão Publicar) colapsa via max-height. Mobile mantém o FAB (mob-visible). */
#fretes-form-header > button#btn-fretes-form-toggle {
  background: var(--primary-soft); color: var(--primary); border: 1px solid var(--primary-ring);
  border-radius: 8px; padding: 6px 12px; font-size: 12px; font-weight: 700; cursor: pointer;
  font-family: inherit; white-space: nowrap; line-height: 1;
}
@media (min-width: 981px) {
  #tab-fretes #form-frete {
    overflow: hidden; max-height: 2600px; opacity: 1;
    transition: max-height 280ms var(--ease-out), opacity 200ms var(--ease-out), margin-top 280ms var(--ease-out);
  }
  #tab-fretes #fretes-form-panel.form-collapsed #form-frete {
    max-height: 0; opacity: 0; margin-top: 0; pointer-events: none;
  }
}
#btn-fretes-form-toggle { display: none; }

/* G6 grid exato dos Motoristas — hover da linha */
.motgrid-row{transition:background .15s}
.motgrid-row:hover{background:var(--primary-soft)}
