/* ============================================================
   CONNECT — Design System (prefixo sv-)
   Paleta oficial da logo CONNECT:
     azul escuro #00598C · teal #04A0AA · lima #CAE945
     verde #8BD058 · cinza #ADB8B7
   Tipografia: Bricolage Grotesque (display) · Public Sans (corpo)
   Documentação: wwwroot/DESIGN-SYSTEM.md
   ------------------------------------------------------------
   CSS único e centralizado. Todas as telas usam estas classes.
   NÃO duplicar CSS nas Views.
   ============================================================ */
:root {
    /* Marca */
    --sv-azul: #00598C;
    --sv-azul-700: #044C77;
    --sv-azul-900: #06314C;
    --sv-teal: #04A0AA;
    --sv-teal-600: #038A93;
    --sv-lima: #CAE945;
    --sv-verde: #8BD058;
    --sv-cinza: #ADB8B7;
    --sv-roxo: #7C5CBF;

    /* Semânticos */
    --sv-success: #5BA829;
    --sv-success-bg: #EAF7DC;
    --sv-warning: #E8A100;
    --sv-warning-bg: #FBF0D5;
    --sv-danger: #C0392B;
    --sv-danger-bg: #FBEAE8;
    --sv-info: #04A0AA;
    --sv-info-bg: #DFF4F5;

    /* Neutros / superfícies */
    --sv-ink: #0E2A3D;
    --sv-text: #28404F;
    --sv-muted: #66808F;
    --sv-line: #E1E9EE;
    --sv-bg: #EEF3F6;
    --sv-surface: #FFFFFF;

    /* Forma */
    --sv-r-sm: 8px;
    --sv-r: 12px;
    --sv-r-lg: 16px;
    --sv-shadow: 0 1px 2px rgba(6,49,76,.04), 0 6px 20px rgba(6,49,76,.07);
    --sv-shadow-lg: 0 18px 48px rgba(6,49,76,.18);
    --sv-ring: 0 0 0 3px rgba(4,160,170,.22);
    --sv-ease: cubic-bezier(.22,.61,.36,1);

    /* Sidebar */
    --sv-nav-0: #00598C;
    --sv-nav-1: #06314C;
    --sv-nav-fg: #BBD3E2;
}

:root[data-theme="dark"]{
  --sv-ink:#EAF2F6; --sv-text:#C4D4DD; --sv-muted:#8AA2AE;
  --sv-line:#24414F; --sv-bg:#0E1A22; --sv-surface:#13242E;
  --sv-success-bg:#16301A; --sv-warning-bg:#3A2E12; --sv-danger-bg:#3A1A16; --sv-info-bg:#0E2E31;
  --sv-nav-0:#0A1A24; --sv-nav-1:#06121A; --sv-nav-fg:#9FBCCB;
  --sv-shadow:0 1px 2px rgba(0,0,0,.30), 0 6px 20px rgba(0,0,0,.40);
  --sv-shadow-lg:0 18px 48px rgba(0,0,0,.55);
  --sv-roxo:#9D86D6;
  color-scheme:dark;
}

* { box-sizing: border-box; }

.sv-body {
    margin: 0;
    font-family: "Public Sans", system-ui, "Segoe UI", sans-serif;
    background: var(--sv-bg);
    color: var(--sv-text);
    font-size: 14.5px; line-height: 1.5;
    -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
h1, h2, h3, .sv-brand, .sv-sidebar-brand { font-family: "Bricolage Grotesque", "Public Sans", sans-serif; }
a { color: var(--sv-teal-600); }
:focus-visible { outline: none; box-shadow: var(--sv-ring); border-radius: 4px; }

/* ===== Shell ===== */
.sv-shell { display: flex; min-height: 100vh; }
.sv-content { flex: 1; display: flex; flex-direction: column; min-width: 0; }

/* ===== Sidebar ===== */
.sv-sidebar {
    width: 248px; flex-shrink: 0;
    background: linear-gradient(185deg, var(--sv-nav-0), var(--sv-nav-1));
    color: var(--sv-nav-fg);
    /* display:block (NÃO flex): flex-column quebrava o scroll interno — itens de baixo
       ficavam inacessíveis (scrollHeight == clientHeight). Block restaura overflow-y. */
    display: block; padding: 6px 12px 22px;
    position: sticky; top: 0; height: 100vh; overflow-y: auto; overflow-x: hidden;
    z-index: 30;
}
.sv-sidebar::-webkit-scrollbar { width: 8px; }
.sv-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.14); border-radius: 8px; }
.sv-sidebar-brand {
    display: flex; align-items: center; gap: 6px;
    padding: 16px 12px; font-weight: 800; font-size: 22px; letter-spacing: .5px; color: #fff;
    position: sticky; top: 0; z-index: 3; background: var(--sv-nav-0);
}
.sv-brand-mark { height: 30px; width: auto; flex: none; filter: drop-shadow(0 1px 3px rgba(0,0,0,.35)); }
.sv-sidebar-brand .sv-dot {
    width: 11px; height: 11px; border-radius: 50%;
    background: var(--sv-lima);
    box-shadow: -7px 0 0 var(--sv-verde), -14px 0 0 var(--sv-teal);
    margin-left: 14px;
}
.sv-menu-group {
    padding: 16px 14px 6px; font-size: 10.5px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em; color: rgba(187,211,226,.55);
}
.sv-menu-item {
    position: relative; display: flex; align-items: center; gap: 11px;
    padding: 9px 14px; margin: 1px 0; color: var(--sv-nav-fg); text-decoration: none;
    font-size: 13.5px; font-weight: 500; border-radius: var(--sv-r-sm);
    white-space: nowrap; overflow: hidden;
    transition: background .18s var(--sv-ease), color .18s var(--sv-ease), transform .18s var(--sv-ease);
}
.sv-menu-item i { width: 17px; height: 17px; opacity: .85; flex-shrink: 0; }
.sv-menu-item:hover { background: rgba(255,255,255,.08); color: #fff; transform: translateX(2px); }
.sv-menu-item.sv-active { background: linear-gradient(90deg, rgba(4,160,170,.30), rgba(4,160,170,.05)); color: #fff; }
.sv-menu-item.sv-active::before {
    content: ""; position: absolute; left: -12px; top: 6px; bottom: 6px; width: 3px;
    border-radius: 0 3px 3px 0; background: var(--sv-lima);
}
.sv-menu-item.sv-active i { opacity: 1; color: var(--sv-lima); }

/* ===== Topbar ===== */
.sv-topbar {
    display: flex; align-items: center; gap: 16px;
    background: rgba(255,255,255,.88); backdrop-filter: saturate(160%) blur(8px);
    border-bottom: 1px solid var(--sv-line); padding: 12px 26px;
    position: sticky; top: 0; z-index: 20;
}
.sv-brand { font-weight: 800; letter-spacing: .5px; color: var(--sv-azul); font-size: 17px; }
.sv-filial-form { margin-left: 4px; }
.sv-filial-select {
    padding: 7px 12px; border-radius: var(--sv-r-sm); border: 1px solid var(--sv-line);
    background: #fff; color: var(--sv-text); font-family: inherit; font-size: 13.5px; cursor: pointer;
}
.sv-filial-select:focus { outline: none; box-shadow: var(--sv-ring); border-color: var(--sv-teal); }
.sv-badge-homolog {
    background: var(--sv-warning); color: #3a2a00; font-weight: 700; font-size: 11px;
    letter-spacing: .04em; padding: 4px 10px; border-radius: 999px;
}
.sv-user {
    margin-left: auto; display: inline-flex; align-items: center; gap: 9px;
    font-size: 13.5px; font-weight: 600; color: var(--sv-ink);
}
.sv-user::before {
    content: attr(data-initial); width: 30px; height: 30px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); color: #fff; font-weight: 700; font-size: 13px;
}
.sv-logout { margin-left: 4px; }
.sv-btn-link {
    background: none; border: 1px solid var(--sv-line); color: var(--sv-muted); cursor: pointer;
    font: inherit; font-size: 13px; padding: 6px 12px; border-radius: var(--sv-r-sm);
    transition: all .18s var(--sv-ease);
}
.sv-btn-link:hover { color: var(--sv-danger); border-color: #f0c4c0; background: var(--sv-danger-bg); }

/* ===== Main ===== */
.sv-main { padding: 26px 30px; animation: sv-rise .4s var(--sv-ease) both; }
@keyframes sv-rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* Breadcrumb + título de página */
.sv-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--sv-muted); margin-bottom: 6px; }
.sv-breadcrumb a { color: var(--sv-muted); text-decoration: none; }
.sv-breadcrumb a:hover { color: var(--sv-teal-600); }
.sv-breadcrumb .sep { opacity: .5; }
.sv-page-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.sv-page-head > div { flex-wrap: wrap; justify-content: flex-end; }
.sv-page-head h1 { margin: 0; color: var(--sv-ink); font-size: 25px; font-weight: 700; letter-spacing: -.01em; }
.sv-page-head .sv-actions { display: flex; gap: 8px; align-items: center; }
h2 { color: var(--sv-ink); font-size: 17px; font-weight: 700; }

/* ===== Cards ===== */
.sv-card { background: var(--sv-surface); border: 1px solid var(--sv-line); border-radius: var(--sv-r-lg); box-shadow: var(--sv-shadow); }
.sv-card h3 { margin: 0 0 12px; font-size: 13px; color: var(--sv-muted); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }

/* Cards de resumo (KPI) */
.sv-summary { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 14px; margin-bottom: 20px; }
.sv-summary-card { background: var(--sv-surface); border: 1px solid var(--sv-line); border-radius: var(--sv-r-lg); box-shadow: var(--sv-shadow); padding: 16px 18px; position: relative; overflow: hidden; }
.sv-summary-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--sv-teal); }
.sv-summary-card.is-azul::before { background: var(--sv-azul); }
.sv-summary-card.is-lima::before { background: var(--sv-lima); }
.sv-summary-card.is-danger::before { background: var(--sv-danger); }
.sv-summary-card .sv-summary-label { font-size: 12px; color: var(--sv-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.sv-summary-card .sv-summary-value { font-family: "Bricolage Grotesque", sans-serif; font-size: 26px; font-weight: 700; color: var(--sv-ink); margin-top: 4px; }

/* ===== Botões ===== */
.sv-btn-primary {
    background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); color: #fff; border: none;
    padding: 11px 16px; border-radius: var(--sv-r-sm); font: 600 14.5px "Public Sans", sans-serif;
    cursor: pointer; display: inline-flex; align-items: center; gap: 7px; justify-content: center;
    box-shadow: 0 2px 8px rgba(4,160,170,.28);
    transition: transform .16s var(--sv-ease), box-shadow .16s var(--sv-ease), filter .16s var(--sv-ease);
}
.sv-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(4,160,170,.36); filter: brightness(1.04); }
.sv-btn-primary:active { transform: translateY(0); }
.sv-btn-secondary {
    background: #fff; border: 1px solid var(--sv-line); color: var(--sv-text); border-radius: var(--sv-r-sm);
    padding: 9px 14px; cursor: pointer; text-decoration: none; font: 600 13.5px "Public Sans", sans-serif;
    display: inline-flex; align-items: center; gap: 6px; transition: all .16s var(--sv-ease);
}
.sv-btn-secondary:hover { border-color: var(--sv-teal); color: var(--sv-teal-600); box-shadow: var(--sv-shadow); }
.sv-btn-sm { font-size: 13px; padding: 7px 12px; width: auto; }
/* variantes semânticas de ação (opcionais) */
.sv-btn-danger { background: linear-gradient(135deg, #D9534F, var(--sv-danger)); color: #fff; border: none; box-shadow: 0 2px 8px rgba(192,57,43,.28); }
.sv-btn-danger:hover { filter: brightness(1.05); transform: translateY(-1px); }

/* ===== Busca / filtros ===== */
.sv-search { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; align-items: center; }
.sv-search input, .sv-search select {
    padding: 9px 13px; border: 1px solid var(--sv-line); border-radius: var(--sv-r-sm);
    background: #fff; font: inherit; font-size: 14px; color: var(--sv-text);
}
.sv-search input { flex: 1; max-width: 380px; }
.sv-search input:focus, .sv-search select:focus { outline: none; border-color: var(--sv-teal); box-shadow: var(--sv-ring); }

/* ===== Tabelas ===== */
.sv-table {
    width: 100%; border-collapse: separate; border-spacing: 0; background: var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: var(--sv-r-lg); overflow: hidden; box-shadow: var(--sv-shadow);
}
.sv-table th, .sv-table td { text-align: left; padding: 12px 16px; font-size: 14px; border-bottom: 1px solid var(--sv-line); }
.sv-table thead th { background: #F4F8FA; color: var(--sv-muted); font-weight: 700; font-size: 11.5px; text-transform: uppercase; letter-spacing: .05em; }
.sv-table tbody tr { transition: background .12s ease; }
.sv-table tbody tr:hover { background: #F1F9FA; }
.sv-table tbody tr:last-child td { border-bottom: none; }
.sv-row-actions { display: flex; gap: 6px; align-items: center; }
.sv-row-actions a, .sv-row-actions button {
    background: none; border: none; cursor: pointer; color: var(--sv-muted);
    width: 30px; height: 30px; border-radius: var(--sv-r-sm);
    display: inline-flex; align-items: center; justify-content: center; transition: all .15s var(--sv-ease);
}
.sv-row-actions a:hover, .sv-row-actions button:hover { background: var(--sv-info-bg); color: var(--sv-teal-600); }
.sv-row-actions a i, .sv-row-actions button i { width: 16px; height: 16px; }
/* .sv-inline-form redefinido na seção FiscalConfig abaixo */

/* ===== Tree-table (Plano de Contas hierárquico) ===== */
.sv-tree-toolbar { display: flex; gap: 8px; margin: 0 0 12px; }
.sv-tree-tbl { border-collapse: separate; border-spacing: 0; }
.sv-tree-tbl td { vertical-align: middle; }
.sv-tree-tbl td:first-child { white-space: nowrap; padding-top: 0; padding-bottom: 0; }
.sv-tree-tbl tbody tr { transition: background .12s var(--sv-ease); }
.sv-tree-tbl tbody tr:hover { background: var(--sv-info-bg); }
/* linhas de grupo (sintético) — leve tinta + texto reforçado */
.sv-tree-tbl tbody tr[data-grp="1"] { background: rgba(0,89,140,.035); }
.sv-tree-tbl tbody tr[data-grp="1"]:hover { background: var(--sv-info-bg); }

.sv-tree-cell { display: flex; align-items: stretch; min-height: 42px; }
.sv-tree-rail { width: 13px; margin-left: 9px; border-left: 1px solid var(--sv-line); flex: none; }
.sv-tree-node { display: inline-flex; align-items: center; gap: 9px; padding-left: 2px; }

.sv-tree-caret {
    width: 22px; height: 22px; flex: none; padding: 0; border: none; background: none;
    cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
    color: var(--sv-muted); border-radius: 6px;
}
.sv-tree-caret:hover { background: rgba(4,160,170,.14); color: var(--sv-teal-600); }
.sv-tree-caret svg { width: 16px; height: 16px; transition: transform .18s var(--sv-ease); }
.sv-tree-caret.is-collapsed svg { transform: rotate(-90deg); }
.sv-tree-bullet { width: 22px; flex: none; display: inline-flex; align-items: center; justify-content: center; }
.sv-tree-bullet::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--sv-line); }

.sv-tree-code {
    font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
    font-size: 12.5px; font-variant-numeric: tabular-nums; letter-spacing: .3px; color: var(--sv-muted);
}
.sv-tree-desc { color: var(--sv-text); }
.sv-tree-tbl tr[data-grp="1"] .sv-tree-code { color: var(--sv-ink); font-weight: 700; }
.sv-tree-tbl tr[data-grp="1"] .sv-tree-desc { color: var(--sv-ink); font-weight: 700; }
.sv-tree-tbl tr[data-depth="0"] .sv-tree-desc {
    font-family: "Bricolage Grotesque", sans-serif; text-transform: uppercase;
    letter-spacing: .4px; font-size: 12.5px;
}

/* badge de natureza (cor + texto, nunca só cor) */
.sv-nat { display: inline-flex; align-items: center; gap: 6px; padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; line-height: 1.7; }
.sv-nat::before { content: ""; width: 7px; height: 7px; border-radius: 50%; }
.sv-nat--rec  { color: #2E6B1E; background: var(--sv-success-bg); }
.sv-nat--rec::before { background: var(--sv-success); }
.sv-nat--desp { color: #9A3329; background: var(--sv-danger-bg); }
.sv-nat--desp::before { background: var(--sv-danger); }
/* chip de tipo */
.sv-tipo { font-size: 11.5px; font-weight: 600; color: var(--sv-muted); text-transform: uppercase; letter-spacing: .3px; }

@media (prefers-reduced-motion: reduce) {
    .sv-tree-caret svg, .sv-tree-tbl tbody tr { transition: none; }
}

/* ===== Badges / status ===== */
.sv-badge-teal, .sv-badge--info { background: var(--sv-info-bg); color: var(--sv-teal-600); }
.sv-badge-red, .sv-badge--danger { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-badge--success { background: var(--sv-success-bg); color: var(--sv-success); }
.sv-badge--warning { background: var(--sv-warning-bg); color: #8a6200; }
.sv-badge--neutral { background: #EEF1F3; color: var(--sv-muted); }
.sv-badge-teal, .sv-badge-red, .sv-badge--info, .sv-badge--danger, .sv-badge--success, .sv-badge--warning, .sv-badge--neutral {
    display: inline-block; font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 999px; line-height: 1.5;
}

/* ===== Alertas ===== */
.sv-ok, .sv-error {
    padding: 11px 14px 11px 40px; border-radius: var(--sv-r); margin-bottom: 16px; font-size: 14px;
    border: 1px solid transparent; position: relative; animation: sv-rise .3s var(--sv-ease) both;
}
.sv-ok::before, .sv-error::before { position: absolute; left: 14px; top: 11px; font-weight: 700; }
.sv-ok { background: var(--sv-success-bg); color: #0F6B47; border-color: #C6E8B0; }
.sv-ok::before { content: "✓"; }
.sv-error { background: var(--sv-danger-bg); color: #9B2218; border-color: #F4C9C3; }
.sv-error::before { content: "!"; }
/* esconde alerta/validação vazios (não mostrar caixa só com "!") */
.sv-ok:empty, .sv-error:empty,
.sv-error.validation-summary-valid,
.sv-ok.field-validation-valid, .sv-error.field-validation-valid { display: none !important; }
.field-validation-valid { display: none; }
.field-validation-error { color: var(--sv-danger); font-size: 12.5px; }

/* ===== Formulários ===== */
.sv-form { background: var(--sv-surface); padding: 26px; border-radius: var(--sv-r-lg); border: 1px solid var(--sv-line); box-shadow: var(--sv-shadow); }
.sv-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sv-col-2 { grid-column: span 2; }
.sv-field { margin-bottom: 2px; display: flex; flex-direction: column; }
.sv-field label { font-size: 12.5px; margin-bottom: 5px; font-weight: 600; color: var(--sv-muted); }
.sv-field input, .sv-field select, .sv-field textarea {
    padding: 10px 12px; border: 1px solid var(--sv-line); border-radius: var(--sv-r-sm);
    font: inherit; font-size: 14.5px; color: var(--sv-ink); background: #fff;
    transition: border-color .15s var(--sv-ease), box-shadow .15s var(--sv-ease);
}
.sv-field input:focus, .sv-field select:focus, .sv-field textarea:focus { outline: none; border-color: var(--sv-teal); box-shadow: var(--sv-ring); }
.sv-field input[readonly] { background: #F2F6F8; color: var(--sv-muted); }
.sv-field-check { flex-direction: row; align-items: center; gap: 8px; }
.sv-field-check label { margin: 0; }
.sv-check { justify-content: center; }
.sv-form-actions { margin-top: 22px; display: flex; gap: 10px; }
fieldset { border: none; padding: 0; margin: 0; }
fieldset:disabled { opacity: .65; }

/* ===== Estados: vazio / carregando ===== */
.sv-empty { text-align: center; padding: 48px 24px; color: var(--sv-muted); }
.sv-empty i { width: 40px; height: 40px; opacity: .4; margin-bottom: 10px; }
.sv-empty p { margin: 4px 0 0; }
.sv-spinner { width: 22px; height: 22px; border: 3px solid var(--sv-line); border-top-color: var(--sv-teal); border-radius: 50%; animation: sv-spin .7s linear infinite; display: inline-block; }
@keyframes sv-spin { to { transform: rotate(360deg); } }
.sv-skeleton { background: linear-gradient(90deg, #eef3f6 25%, #e2eaef 37%, #eef3f6 63%); background-size: 400% 100%; animation: sv-shimmer 1.3s ease infinite; border-radius: 6px; height: 14px; }
@keyframes sv-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ===== Login ===== */
.sv-login-stage {
    min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px;
    background:
        radial-gradient(60% 70% at 12% 8%, rgba(0,89,140,.55), transparent 60%),
        radial-gradient(55% 65% at 92% 16%, rgba(4,160,170,.50), transparent 55%),
        radial-gradient(70% 70% at 80% 100%, rgba(202,233,69,.30), transparent 55%),
        #06314C;
    position: relative; overflow: hidden;
}
.sv-login-stage::after {
    content: ""; position: absolute; inset: 0; opacity: .045; pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.sv-login-wrap {
    max-width: 400px; padding: 40px 36px; background: rgba(255,255,255,.94);
    border: 1px solid rgba(255,255,255,.6); border-radius: 20px; box-shadow: var(--sv-shadow-lg);
    backdrop-filter: blur(10px); position: relative; z-index: 2; animation: sv-rise .5s var(--sv-ease) both;
}
.sv-login-wrap h1 { color: var(--sv-azul); margin: 0 0 4px; text-align: center; font-size: 34px; font-weight: 800; letter-spacing: .5px; }
.sv-login-sub { text-align: center; color: var(--sv-muted); font-size: 13px; margin: 0 0 26px; }
.sv-login-wrap .sv-field { margin-bottom: 16px; }
.sv-login-wrap .sv-btn-primary { width: 100%; margin-top: 6px; padding: 12px; }

/* ===== Login — duas colunas (institucional + form) ===== */
.sv-login-card {
    position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr 1fr;
    width: 100%; max-width: 880px; min-height: 520px; border-radius: 22px; overflow: hidden;
    background: rgba(255,255,255,.96); border: 1px solid rgba(255,255,255,.5);
    box-shadow: var(--sv-shadow-lg); backdrop-filter: blur(12px); animation: sv-rise .5s var(--sv-ease) both;
}
.sv-login-aside {
    position: relative; padding: 40px 38px; color: #eaf4f8; display: flex; flex-direction: column; gap: 26px;
    background:
        radial-gradient(80% 60% at 100% 0%, rgba(4,160,170,.55), transparent 60%),
        radial-gradient(70% 60% at 0% 100%, rgba(202,233,69,.22), transparent 55%),
        linear-gradient(160deg, var(--sv-azul), var(--sv-azul-900));
}
.sv-login-aside .sv-logo { background: rgba(255,255,255,.95); padding: 12px 18px; border-radius: 16px; align-self: flex-start; }
.sv-login-aside .sv-logo-img { height: 84px; }
.sv-login-brand { font-family: "Bricolage Grotesque", sans-serif; font-size: 30px; font-weight: 800; letter-spacing: 1.5px; color: var(--sv-lima); margin: 16px 0 0; line-height: 1.1; }
.sv-login-aside-title { font-family: "Bricolage Grotesque", sans-serif; font-size: 24px; font-weight: 800; color: #fff; margin: 6px 0 4px; line-height: 1.2; }
.sv-login-aside-sub { margin: 0; opacity: .85; font-size: 13.5px; }
.sv-login-features { list-style: none; margin: auto 0; padding: 0; display: grid; gap: 11px; }
.sv-login-features li { display: flex; align-items: center; gap: 11px; font-size: 14px; font-weight: 500; }
.sv-login-features li svg { width: 18px; height: 18px; color: var(--sv-lima); flex-shrink: 0; }
.sv-login-aside-foot { display: flex; flex-direction: column; gap: 2px; font-size: 13px; opacity: .92; border-top: 1px solid rgba(255,255,255,.16); padding-top: 16px; }
.sv-login-aside-foot strong { color: #fff; font-size: 14px; }
.sv-login-form { padding: 44px 40px; display: flex; flex-direction: column; justify-content: center; background: #fff; }
.sv-login-form-head h1 { color: var(--sv-azul); margin: 0 0 2px; font-size: 28px; font-weight: 800; }
.sv-login-form .sv-field { margin-bottom: 15px; }
.sv-login-form .sv-btn-primary { width: 100%; margin-top: 8px; padding: 12px; }
.sv-login-opts { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 4px 0 6px; }
.sv-login-meta { display: flex; align-items: center; gap: 8px; justify-content: center; margin-top: 22px; font-size: 12px; color: var(--sv-muted); }
.sv-login-meta .sv-dot-sep { opacity: .5; }
@media (max-width: 760px) {
    .sv-login-card { grid-template-columns: 1fr; max-width: 440px; min-height: 0; }
    .sv-login-aside { display: none; }
    .sv-login-form { padding: 34px 28px; }
}

/* ===== Ícones (Lucide vira <svg>) — normaliza tamanho ===== */
.sv-menu-item svg { width: 18px; height: 18px; flex-shrink: 0; }
.sv-btn-primary svg, .sv-btn-secondary svg, .sv-btn-link svg { width: 16px; height: 16px; }
.sv-row-actions svg { width: 16px; height: 16px; }
.sv-page-head svg { width: 16px; height: 16px; }

/* ===== Logo CONNECT ===== */
.sv-logo { display: inline-flex; align-items: center; gap: 10px; }
.sv-logo svg { width: 38px; height: 38px; }
.sv-logo-img { height: 40px; width: auto; display: block; }
.sv-login-wrap .sv-logo-img { height: 96px; }
.sv-card .sv-logo-img { height: 76px; }
.sv-logo .sv-logo-text { font-family: "Bricolage Grotesque", sans-serif; font-weight: 800; letter-spacing: .5px; }
.sv-org { color: var(--sv-muted); font-size: 12px; }
.sv-org strong { color: var(--sv-ink); }

/* ===== Sidebar: busca + grupos colapsáveis + recentes ===== */
.sv-nav-search { position: relative; margin: 6px 6px 10px; }
.sv-rec-right { margin-left: auto; display: inline-flex; align-items: center; gap: 7px; }
.sv-rec-count { background: rgba(255,255,255,.16); color: #fff; font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 999px; }
#grp-recentes .sv-caret { opacity: .95; color: var(--sv-lima); }
.sv-nav-search input {
    width: 100%; padding: 8px 12px 8px 32px; border-radius: var(--sv-r-sm);
    border: 1px solid var(--sv-line); background: #fff;
    color: var(--sv-ink); font: inherit; font-size: 13px;
}
.sv-nav-search input::placeholder { color: var(--sv-muted); }
.sv-nav-search input:focus { outline: none; border-color: var(--sv-teal); box-shadow: var(--sv-ring); }
.sv-nav-search::before {
    content: ""; position: absolute; left: 11px; top: 50%; width: 13px; height: 13px; transform: translateY(-50%);
    background: var(--sv-muted);
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2'%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;
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2'%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;
}
.sv-menu-group { cursor: pointer; display: flex; align-items: center; justify-content: space-between; user-select: none; border-radius: var(--sv-r-sm); transition: color .15s var(--sv-ease); }
.sv-menu-group:not(.sv-menu-group--static):hover { color: rgba(255,255,255,.85); }
.sv-menu-group--static { cursor: default; }
.sv-menu-rec-toggle { cursor: pointer; }
/* Rail (menu recolhido p/ ícones) — toggle manual no desktop */
.sv-rail-toggle { background: none; border: 1px solid var(--sv-line); color: var(--sv-muted); width: 36px; height: 36px; border-radius: var(--sv-r-sm); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .15s var(--sv-ease); }
.sv-rail-toggle:hover { color: var(--sv-teal-600); border-color: var(--sv-teal); }
.sv-rail-toggle svg { width: 18px; height: 18px; }
/* Hambúrguer (drawer mobile) + backdrop — ocultos no desktop, exibidos no @media ≤860px */
.sv-nav-toggle { display: none; background: none; border: 1px solid var(--sv-line); color: var(--sv-azul);
    width: 38px; height: 38px; border-radius: var(--sv-r-sm); cursor: pointer; align-items: center; justify-content: center; flex-shrink: 0; }
.sv-nav-toggle:hover { color: var(--sv-teal-600); border-color: var(--sv-teal); }
.sv-nav-toggle svg { width: 20px; height: 20px; }
.sv-drawer-backdrop { display: none; }
@media (max-width: 860px) { .sv-drawer-backdrop { display: block; } }
.sv-shell.is-rail .sv-sidebar { width: 64px; }
.sv-shell.is-rail .sv-sidebar-brand span:not(.sv-dot) { display: none; }
.sv-shell.is-rail .sv-sidebar-brand .sv-dot { display: none; }
.sv-shell.is-rail .sv-sidebar-brand { justify-content: center; padding: 16px 0; }
.sv-shell.is-rail .sv-nav-search { display: none; }
.sv-shell.is-rail .sv-menu-group { font-size: 0; padding: 10px 0 4px; justify-content: center; }
.sv-shell.is-rail .sv-menu-group .sv-rec-right, .sv-shell.is-rail .sv-menu-group .sv-caret { display: none; }
.sv-shell.is-rail .sv-menu-item span { display: none; }
.sv-shell.is-rail .sv-menu-item { justify-content: center; padding: 11px 0; }
.sv-shell.is-rail .sv-menu-item i, .sv-shell.is-rail .sv-menu-item svg { width: 20px; height: 20px; }
.sv-menu-rec-toggle:hover { color: rgba(255,255,255,.85); }
.sv-menu-item--solo { margin-top: 2px; }
.sv-menu-group svg, .sv-menu-group .sv-caret { width: 15px; height: 15px; flex-shrink: 0; }
.sv-menu-group .sv-caret { transition: transform .2s var(--sv-ease); opacity: .7; }
.sv-menu-group.is-collapsed .sv-caret { transform: rotate(-90deg); }
.sv-menu-section { overflow: hidden; transition: max-height .25s var(--sv-ease); }
.sv-menu-section.is-collapsed { max-height: 0 !important; }
.sv-menu-item.is-hidden, .sv-menu-group.is-hidden { display: none; }
.sv-recent-empty { padding: 4px 14px 8px; font-size: 11.5px; color: rgba(187,211,226,.45); }

/* ===== Botão de Ajuda (todas as telas) ===== */
.sv-help-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--sv-line);
    background: #fff; color: var(--sv-teal-600); cursor: pointer; flex-shrink: 0;
    transition: all .16s var(--sv-ease);
}
.sv-help-btn:hover { background: var(--sv-info-bg); border-color: var(--sv-teal); transform: translateY(-1px); box-shadow: var(--sv-shadow); }
.sv-help-btn svg { width: 18px; height: 18px; }
.sv-help-body { text-align: left; font-size: 14px; color: var(--sv-text); line-height: 1.6; }
.sv-help-body h4 { font-family: "Bricolage Grotesque", sans-serif; color: var(--sv-azul); margin: 14px 0 6px; font-size: 15px; }
.sv-help-body ul { margin: 6px 0; padding-left: 20px; }
.sv-help-body li { margin: 3px 0; }
.sv-help-body .sv-help-lead { background: var(--sv-info-bg); border-radius: var(--sv-r); padding: 10px 12px; color: var(--sv-ink); }

/* ===== Obrigatório / contador ===== */
.sv-required { color: var(--sv-danger); font-weight: 700; margin-left: 2px; }
.sv-check-inline { display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; color: var(--sv-muted); white-space: nowrap; cursor: pointer; }
.sv-check-inline input { width: 16px; height: 16px; accent-color: var(--sv-teal); }
.sv-count { display: inline-block; font-size: 12px; font-weight: 700; color: var(--sv-muted);
    background: var(--sv-line); border-radius: 999px; padding: 1px 9px; vertical-align: middle; margin-left: 6px; }

/* ===== Status de linha / saldo nas grids ===== */
.sv-table tbody tr.sv-row--inativo td { color: var(--sv-danger); }
.sv-table tbody tr.sv-row--inativo td:first-child { box-shadow: inset 3px 0 0 var(--sv-danger); }
.sv-saldo--neg { color: var(--sv-danger); font-weight: 700; }
.sv-saldo--ok { color: var(--sv-success); font-weight: 700; }
.sv-saldo--baixo { color: #8a5a2b; font-weight: 700; } /* marrom */

/* ===== Abas (Produto e afins) ===== */
.sv-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--sv-line); margin-bottom: 18px; flex-wrap: wrap; }
.sv-tab { padding: 9px 16px; border: none; background: none; cursor: pointer; font: 600 14px "Public Sans", sans-serif;
    color: var(--sv-muted); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all .15s var(--sv-ease); display: inline-flex; align-items: center; gap: 6px; }
.sv-tab:hover { color: var(--sv-teal-600); }
.sv-tab.is-active { color: var(--sv-azul); border-bottom-color: var(--sv-teal); }
.sv-tabpane { display: none; }
.sv-tabpane.is-active { display: block; animation: sv-rise .25s var(--sv-ease) both; }

/* ===== Imagem de produto ===== */
.sv-prod-thumb { width: 40px; height: 40px; object-fit: cover; border-radius: 8px; border: 1px solid var(--sv-line); background: #fff; }
.sv-prod-foto { max-height: 160px; max-width: 100%; width: auto; object-fit: contain; border: 1px solid var(--sv-line); border-radius: 10px; background: #fff; padding: 4px; }

/* ===== Grids modernas (refino) ===== */
.sv-table thead th { position: sticky; top: 0; z-index: 1; box-shadow: inset 0 -1px 0 var(--sv-line); }
.sv-table tbody tr:nth-child(even) { background: #FBFCFD; }
.sv-table tbody tr:hover { background: #ECF7F8; }
.sv-table-wrap { overflow-x: auto; border-radius: var(--sv-r-lg); }

/* ===== Card longo do certificado (Config Fiscal) ===== */
.sv-cert-card { display: flex; gap: 18px; align-items: center; padding: 20px 24px; margin-bottom: 20px; border-left: 5px solid var(--sv-teal); }
.sv-cert-card.is-ok { border-left-color: var(--sv-success); }
.sv-cert-card.is-warn { border-left-color: var(--sv-warning); }
.sv-cert-card.is-danger { border-left-color: var(--sv-danger); }
.sv-cert-ico { width: 56px; height: 56px; border-radius: 14px; background: var(--sv-info-bg); color: var(--sv-teal-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sv-cert-ico svg { width: 28px; height: 28px; }
.sv-cert-body { flex: 1; min-width: 0; }
.sv-cert-titulo { font-family: "Bricolage Grotesque", sans-serif; font-size: 18px; font-weight: 700; color: var(--sv-ink); margin-bottom: 10px; }
.sv-cert-linhas { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 8px 22px; }
.sv-cert-linhas .lbl { display: block; font-size: 10.5px; text-transform: uppercase; letter-spacing: .04em; color: var(--sv-muted); font-weight: 700; }
.sv-cert-linhas b { font-size: 14.5px; color: var(--sv-ink); }
.sv-desc-wrap { display: flex; gap: 4px; align-items: center; }

/* ===== FiscalConfig — layout harmonioso (Task J-5) ===== */
/* Layout máximo para as seções fiscais */
.sv-fiscal-section { max-width: 780px; }
/* Espaçamento uniforme entre seções */
.sv-fiscal-section + .sv-fiscal-section,
.sv-fiscal-form + .sv-fiscal-section { margin-top: 1.25rem; }
.sv-fiscal-form { max-width: 780px; display: flex; flex-direction: column; gap: 1.25rem; }

/* Header de card padronizado */
.sv-card-header {
    display: flex; align-items: center; gap: .55rem;
    padding: 14px 20px; border-bottom: 1px solid var(--sv-line);
    font-size: 14.5px; color: var(--sv-ink);
}
.sv-card-header svg { width: 18px; height: 18px; color: var(--sv-teal-600); flex-shrink: 0; }
.sv-card-header strong { font-weight: 700; }
.sv-card-header .sv-card-badge { margin-left: auto; }

/* Corpo do card */
.sv-card-body { padding: 16px 20px; }
.sv-card-body .sv-card-hint { margin: 0 0 .85rem; }

/* Badges inline no header (ok/error sem margin/padding padrão) */
.sv-card-header .sv-ok,
.sv-card-header .sv-error {
    margin: 0; padding: .15rem .5rem;
    font-size: 12.5px; border-radius: 999px;
}
.sv-card-header .sv-ok::before,
.sv-card-header .sv-error::before { position: static; left: auto; top: auto; margin-right: .3rem; }

/* Campos read-only (substituem .sv-cert-linhas) */
.sv-readonly {
    padding: .55rem .7rem;
    background: var(--sv-bg);
    border: 1px solid var(--sv-line);
    border-radius: var(--sv-r-sm);
    color: var(--sv-text);
    min-height: 38px;
    display: flex; align-items: center;
    word-break: break-word;
    font-size: 14.5px;
}
.sv-readonly b { font-weight: 600; color: var(--sv-ink); }

/* Forms inline nas tabelas de filial/caixa */
.sv-inline-form { display: inline-flex; gap: .4rem; align-items: center; }
.sv-inline-input {
    padding: 7px 10px; border: 1px solid var(--sv-line); border-radius: var(--sv-r-sm);
    font: inherit; font-size: 14px; color: var(--sv-ink); background: #fff;
    transition: border-color .15s var(--sv-ease), box-shadow .15s var(--sv-ease);
}
.sv-inline-input:focus { outline: none; border-color: var(--sv-teal); box-shadow: var(--sv-ring); }
.sv-w-serie  { width: 70px; text-align: center; }
.sv-w-num    { width: 120px; }

/* Responsivo: colunas colapsam abaixo de 860px (já coberto por .sv-form-grid) */
@media (max-width: 860px) {
    .sv-fiscal-section { max-width: 100%; }
    .sv-fiscal-form    { max-width: 100%; }
}
.sv-desc-wrap select { padding: 6px 4px; font-size: 12px; }
.sv-grid-3 { grid-template-columns: repeat(3, 1fr) !important; }
@media (max-width: 860px) { .sv-grid-3 { grid-template-columns: 1fr !important; } }

/* ===== Validade do certificado no Home (abaixo do "Olá") ===== */
.sv-cert-hint { display: inline-flex; align-items: center; gap: 7px; margin-top: 6px; font-size: 13px; font-weight: 600; padding: 5px 12px; border-radius: 999px; background: var(--sv-success-bg); color: var(--sv-success); }
.sv-cert-hint.is-warn { background: var(--sv-warning-bg); color: #8a6200; }
.sv-cert-hint.is-danger { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-cert-hint svg { width: 15px; height: 15px; }

/* ===== Dashboard Executivo ===== */
.sv-hero {
    display: flex; align-items: center; gap: 20px; flex-wrap: wrap; padding: 22px 24px; margin-bottom: 22px;
    border: none; color: #eaf4f8;
    background: radial-gradient(70% 120% at 100% 0%, rgba(4,160,170,.55), transparent 60%), linear-gradient(120deg, var(--sv-azul-900), var(--sv-azul) 60%, var(--sv-teal));
}
.sv-hero .sv-logo { background: rgba(255,255,255,.95); padding: 8px 12px; border-radius: 14px; }
.sv-hero .sv-logo-img { height: 66px; }
.sv-hero-mid { flex: 1; min-width: 230px; }
.sv-hero-title { font-family: "Bricolage Grotesque", sans-serif; font-size: 23px; font-weight: 800; color: #fff; }
.sv-hero-mid p { margin: 4px 0 0; opacity: .9; }
.sv-hero-org { text-align: right; font-size: 12.5px; opacity: .9; line-height: 1.6; }
.sv-hero-org strong { color: #fff; }
.sv-dash-h { margin: 22px 0 12px; font-size: 14px; text-transform: uppercase; letter-spacing: .06em; color: var(--sv-muted); }
.sv-dash-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.sv-dash-card {
    display: block; text-decoration: none; color: inherit; background: var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: var(--sv-r-lg); box-shadow: var(--sv-shadow);
    padding: 16px 18px; position: relative; overflow: hidden; transition: transform .16s var(--sv-ease), box-shadow .16s var(--sv-ease);
}
.sv-dash-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--sv-teal); }
.sv-dash-card.is-azul::before { background: var(--sv-azul); }
.sv-dash-card.is-teal::before { background: var(--sv-teal); }
.sv-dash-card.is-verde::before { background: var(--sv-verde); }
.sv-dash-card.is-lima::before { background: var(--sv-lima); }
.sv-dash-card.is-danger::before { background: var(--sv-danger); }
.sv-dash-card.is-warning::before { background: var(--sv-warning); }
.sv-dash-card:hover { transform: translateY(-2px); box-shadow: var(--sv-shadow-lg); }
.sv-dash-card-head { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--sv-muted); text-transform: uppercase; letter-spacing: .03em; }
.sv-dash-card-head svg { width: 17px; height: 17px; color: var(--sv-teal-600); }
.sv-dash-card-value { font-family: "Bricolage Grotesque", sans-serif; font-size: 30px; font-weight: 800; color: var(--sv-ink); margin: 8px 0 10px; }
.sv-dash-card-foot { display: flex; flex-wrap: wrap; gap: 6px; }
.sv-pill { font-size: 11.5px; font-weight: 700; padding: 2px 9px; border-radius: 999px; }
.sv-pill--ok { background: var(--sv-success-bg); color: var(--sv-success); }
.sv-pill--off { background: #EEF1F3; color: var(--sv-muted); }
.sv-pill--danger { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-pill--warning { background: var(--sv-warning-bg); color: #8a6200; }
.sv-pill--neutral { background: var(--sv-info-bg); color: var(--sv-teal-600); }
.sv-dash-charts { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sv-chart-card { padding: 18px 20px; }
.sv-col-span-2 { grid-column: span 2; }
.sv-chart-empty { padding: 28px; text-align: center; color: var(--sv-muted); font-size: 13.5px; }
@media (max-width: 860px) { .sv-dash-charts { grid-template-columns: 1fr; } .sv-col-span-2 { grid-column: span 1; } }

/* ===== Modal (visualização rápida 👁) ===== */
.sv-modal-overlay {
    position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 20px;
    background: rgba(6,49,76,.5); backdrop-filter: blur(3px); opacity: 0; pointer-events: none; transition: opacity .2s var(--sv-ease);
}
.sv-modal-overlay.is-open { opacity: 1; pointer-events: auto; }
.sv-modal {
    background: var(--sv-surface); border-radius: var(--sv-r-lg); box-shadow: var(--sv-shadow-lg);
    width: 100%; max-width: 560px; max-height: 88vh; overflow: auto; transform: translateY(10px) scale(.98); transition: transform .2s var(--sv-ease);
}
.sv-modal-overlay.is-open .sv-modal { transform: none; }
.sv-modal-head { display: flex; align-items: center; gap: 12px; padding: 18px 22px; border-bottom: 1px solid var(--sv-line); position: sticky; top: 0; background: var(--sv-surface); }
.sv-modal-head h3 { margin: 0; font-family: "Bricolage Grotesque", sans-serif; font-size: 17px; color: var(--sv-ink); flex: 1; }
.sv-modal-close { background: none; border: none; cursor: pointer; color: var(--sv-muted); width: 32px; height: 32px; border-radius: var(--sv-r-sm); display: inline-flex; align-items: center; justify-content: center; }
.sv-modal-close:hover { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-modal-body { padding: 18px 20px; }
.sv-modal-loading { text-align: center; padding: 30px; }
/* Timeline de histórico (AuditLog) */
.sv-timeline { list-style: none; margin: 0; padding: 0; }
.sv-tl-item { border-left: 3px solid var(--sv-teal); padding: 8px 0 8px 14px; margin-left: 4px; position: relative; }
.sv-tl-item::before { content: ""; position: absolute; left: -7px; top: 12px; width: 11px; height: 11px; border-radius: 50%; background: var(--sv-teal); border: 2px solid #fff; }
.sv-tl--Criado { border-left-color: var(--sv-success); } .sv-tl--Criado::before { background: var(--sv-success); }
.sv-tl--Excluído { border-left-color: var(--sv-danger); } .sv-tl--Excluído::before { background: var(--sv-danger); }
.sv-tl--ok { border-left-color: var(--sv-success); } .sv-tl--ok::before { background: var(--sv-success); }
.sv-tl--rej { border-left-color: var(--sv-danger); } .sv-tl--rej::before { background: var(--sv-danger); }
.sv-tl--cancel { border-left-color: var(--sv-cinza); } .sv-tl--cancel::before { background: var(--sv-cinza); }
.sv-tl--info { border-left-color: var(--sv-info); } .sv-tl--info::before { background: var(--sv-info); }
.sv-tl-head { font-size: 13px; color: var(--sv-ink); }
.sv-tl-data { color: var(--sv-muted); font-size: 11.5px; }
.sv-tl-res { font-size: 11px; color: var(--sv-muted); margin-top: 3px; word-break: break-word; font-family: "JetBrains Mono", monospace; background: #f4f8fa; border-radius: 6px; padding: 4px 8px; max-height: 70px; overflow: auto; }
.sv-tl-desc { font-size: 13px; color: var(--sv-text); margin-top: 3px; }
.sv-tl-tec { margin-top: 5px; }
.sv-tl-tec > summary { cursor: pointer; font-size: 11.5px; color: var(--sv-teal-600); list-style: none; }
.sv-tl-tec > summary::-webkit-details-marker { display: none; }
.sv-tl-tec[open] > summary { margin-bottom: 4px; }

/* Visualização rápida (👁) — compacta */
.sv-qv { display: grid; grid-template-columns: 124px 1fr; gap: 18px; align-items: start; }
.sv-qv.sv-qv--nomedia { grid-template-columns: 1fr; }
.sv-qv-media { position: sticky; top: 0; }
.sv-qv-foto { width: 124px; height: 124px; object-fit: contain; border: 1px solid var(--sv-line); border-radius: 14px; background: #fff; padding: 6px; }
.sv-qv-foto--vazia { display: flex; align-items: center; justify-content: center; color: var(--sv-cinza); background: #F4F8FA; }
.sv-qv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; }
.sv-qv-cell { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.sv-qv-k { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--sv-muted); }
.sv-qv-v { font-size: 14px; font-weight: 600; color: var(--sv-ink); overflow-wrap: anywhere; }
.sv-qv-v--neg { color: var(--sv-danger); }
.sv-qv-v--ok { color: var(--sv-success); }
@media (max-width: 520px) {
    .sv-qv { grid-template-columns: 1fr; justify-items: center; text-align: center; }
    .sv-qv-grid { grid-template-columns: 1fr; text-align: left; width: 100%; }
}

/* Avatar de usuário */
.sv-avatar-upload { display: flex; align-items: center; gap: 16px; }
.sv-avatar-preview { width: 92px; height: 92px; border-radius: 50%; object-fit: cover; border: 3px solid #fff; box-shadow: var(--sv-shadow); background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #fff; font: 800 30px "Bricolage Grotesque", sans-serif; }
.sv-avatar-preview img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.sv-logo-box { width: 200px; height: 100px; border: 1px dashed var(--sv-line); border-radius: 12px; background: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.sv-logo-box img { max-width: 100%; max-height: 100%; object-fit: contain; }
.sv-logo-box span { color: var(--sv-cinza); }
.sv-logo-box span svg { width: 34px; height: 34px; }
.sv-avatar-acts { display: flex; flex-direction: column; gap: 6px; }
.sv-avatar-hint { font-size: 12px; color: var(--sv-muted); }
.sv-user-thumb { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; border: 1px solid var(--sv-line); background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); color: #fff; display: inline-flex; align-items: center; justify-content: center; font: 700 13px "Bricolage Grotesque", sans-serif; vertical-align: middle; }
.sv-user-thumb img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }

/* ===== Segurança: matriz de permissões + perfis ===== */
.sv-section { margin: 22px 0 10px; font-size: 14px; color: var(--sv-ink); font-weight: 700; border-bottom: 1px solid var(--sv-line); padding-bottom: 6px; }
.sv-matriz-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 22px 0 10px; border-bottom: 1px solid var(--sv-line); padding-bottom: 6px; flex-wrap: wrap; }
.sv-matriz-head h3 { margin: 0; border: none; padding: 0; }
.sv-matriz-mod { margin-bottom: 16px; }
.sv-matriz-modhead { display: flex; align-items: center; gap: 14px; background: #F4F8FA; border: 1px solid var(--sv-line); border-bottom: none; border-radius: var(--sv-r-sm) var(--sv-r-sm) 0 0; padding: 8px 12px; }
.sv-matriz-modhead strong { color: var(--sv-azul); }
.sv-matriz-tbl { border-radius: 0 0 var(--sv-r-sm) var(--sv-r-sm); box-shadow: none; }
.sv-matriz-tbl th, .sv-matriz-tbl td { padding: 7px 10px; text-align: center; }
.sv-matriz-tbl th:first-child, .sv-matriz-tbl td:first-child { text-align: left; }
.sv-matriz-cell input { width: 17px; height: 17px; accent-color: var(--sv-teal); cursor: pointer; }
.sv-matriz-na { color: var(--sv-line); }
.sv-check-wrap { align-self: end; padding-bottom: 9px; }
.sv-perfis-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.sv-perfil-chk { display: flex; align-items: flex-start; gap: 10px; border: 1px solid var(--sv-line); border-radius: var(--sv-r-sm); padding: 10px 12px; cursor: pointer; transition: all .15s var(--sv-ease); }
.sv-perfil-chk:hover { border-color: var(--sv-teal); background: var(--sv-info-bg); }
.sv-perfil-chk input { width: 17px; height: 17px; accent-color: var(--sv-teal); margin-top: 2px; }
.sv-perfil-chk span { display: flex; flex-direction: column; }
.sv-perfil-chk small { color: var(--sv-muted); font-size: 12px; }

/* ===== SweetAlert2 — tema CONNECT (dark-aware, sofisticado) ===== */
/* NOTA: background dos botões NÃO é forçado aqui para que confirmButtonColor/
         cancelButtonColor inline (definidos nos helpers SV.*) prevaleçam.      */

/* Popup principal */
.swal2-popup {
    border-radius: var(--sv-r-lg) !important;
    box-shadow: var(--sv-shadow-lg) !important;
    background: var(--sv-surface) !important;
    color: var(--sv-text) !important;
    font-family: "Public Sans", system-ui, "Segoe UI", sans-serif !important;
    padding: 2rem 2rem 1.75rem !important;
    border: 1px solid var(--sv-line) !important;
}

/* Título */
.swal2-title {
    font-family: "Bricolage Grotesque", "Public Sans", sans-serif !important;
    color: var(--sv-ink) !important;
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
    padding: 0 0 .25rem !important;
}

/* Corpo / html-container */
.swal2-html-container {
    color: var(--sv-text) !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
    margin: .35rem 0 0 !important;
}

/* Botões — forma e tipografia apenas; COR vem do inline confirmButtonColor */
.swal2-styled {
    border-radius: var(--sv-r) !important;
    padding: .55rem 1.25rem !important;
    font-family: "Public Sans", sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    letter-spacing: .01em !important;
    transition: filter .15s var(--sv-ease), transform .12s var(--sv-ease), box-shadow .15s var(--sv-ease) !important;
    border: none !important;
    outline: none !important;
}
.swal2-styled:hover { filter: brightness(1.08); transform: translateY(-1px) !important; }
.swal2-styled:active { filter: brightness(.96); transform: translateY(0) !important; }
.swal2-styled:focus-visible { outline: none !important; box-shadow: var(--sv-ring) !important; }
/* Foco legacy (SweetAlert2 usa :focus, não :focus-visible) */
.swal2-styled:focus { outline: none !important; box-shadow: var(--sv-ring) !important; }

/* Botão cancelar: tom neutro por default quando não há cancelButtonColor */
.swal2-styled.swal2-cancel {
    background: var(--sv-bg) !important;
    color: var(--sv-text) !important;
}
/* Se cancelButtonColor inline for definido, o atributo style do elemento tem priority;
   a regra acima só atua quando não há style. SweetAlert2 injeta o style diretamente,
   então o inline style (especificidade 1000) sobrescreve a regra acima automaticamente. */

/* Actions container (barra de botões) */
.swal2-actions {
    gap: .625rem !important;
    margin-top: 1.5rem !important;
}

/* Campos de entrada */
.swal2-input,
.swal2-textarea,
.swal2-select {
    border: 1px solid var(--sv-line) !important;
    border-radius: var(--sv-r-sm) !important;
    background: var(--sv-surface) !important;
    color: var(--sv-text) !important;
    font-family: "Public Sans", sans-serif !important;
    font-size: 14px !important;
    padding: .55rem .75rem !important;
    box-shadow: none !important;
    transition: border-color .15s var(--sv-ease), box-shadow .15s var(--sv-ease) !important;
}
.swal2-input:focus,
.swal2-textarea:focus,
.swal2-select:focus {
    border-color: var(--sv-teal) !important;
    box-shadow: var(--sv-ring) !important;
    outline: none !important;
}

/* Mensagem de validação */
.swal2-validation-message {
    background: var(--sv-danger-bg) !important;
    color: var(--sv-danger) !important;
    border-radius: var(--sv-r-sm) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    border: 1px solid rgba(192,57,43,.18) !important;
}

/* Ícone — apenas ajuste de margem */
.swal2-icon {
    margin: 0 auto .75rem !important;
}

/* Barra de timer */
.swal2-timer-progress-bar {
    background: var(--sv-teal) !important;
    height: 3px !important;
    border-radius: 2px !important;
}

/* TOASTS */
.swal2-toast {
    border-radius: 12px !important;
    box-shadow: var(--sv-shadow-lg) !important;
    border: 1px solid var(--sv-line) !important;
    background: var(--sv-surface) !important;
    color: var(--sv-text) !important;
    padding: .7rem 1rem !important;
    font-family: "Public Sans", sans-serif !important;
    align-items: center !important;
}
.swal2-toast .swal2-title {
    font-size: .95rem !important;
    font-weight: 700 !important;
    color: var(--sv-ink) !important;
}
.swal2-toast .swal2-timer-progress-bar {
    background: var(--sv-teal) !important;
}
/* Evitar quebra no conteúdo customizado de SV.notify (.sv-toast-img) */
.swal2-toast .swal2-html-container {
    margin: 0 !important;
    font-size: 13px !important;
}
.sv-toast-img { display: flex; align-items: center; gap: 10px; }
.sv-toast-img img { width: 36px; height: 36px; object-fit: cover; border-radius: 8px; flex: none; }
.sv-toast-ic { width: 32px; height: 32px; border-radius: 8px; font-size: 15px; flex: none; }

/* Backdrop (container) — escurecimento + leve blur elegante */
.swal2-container.swal2-backdrop-show {
    background: rgba(6,49,76,.45) !important;
    backdrop-filter: blur(3px) !important;
    -webkit-backdrop-filter: blur(3px) !important;
}
/* Toast em cantos NÃO deve herdar o backdrop — remove faixa lateral */
.swal2-container.swal2-top, .swal2-container.swal2-top-start, .swal2-container.swal2-top-end,
.swal2-container.swal2-bottom, .swal2-container.swal2-bottom-start, .swal2-container.swal2-bottom-end {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

/* Animação de entrada suave (complementa a animação padrão do swal2) */
@keyframes sv-swal-in {
    from { opacity: 0; transform: scale(.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1)  translateY(0);   }
}
.swal2-show { animation: sv-swal-in .22s var(--sv-ease) both !important; }

/* Dark theme: as variáveis --sv-surface, --sv-ink, --sv-text, --sv-line,
   --sv-bg já são sobrescritas por :root[data-theme="dark"] — todos os
   seletores acima herdam automaticamente as cores escuras sem regras extras. */

/* ===== Responsivo ===== */
@media (max-width: 1024px) { .sv-main { padding: 22px 20px; } }
@media (max-width: 860px) {
    /* Sidebar vira drawer off-canvas (labels completos), abre pelo hambúrguer. */
    .sv-sidebar {
        position: fixed; top: 0; left: 0; height: 100vh; width: 270px; max-width: 84vw;
        transform: translateX(-100%); transition: transform .26s var(--sv-ease); z-index: 60;
        box-shadow: 4px 0 22px rgba(6,49,76,.18);
    }
    .sv-shell.is-drawer-open .sv-sidebar { transform: translateX(0); }
    /* No mobile o "rail" não se aplica — sempre labels completos no drawer. */
    .sv-shell.is-rail .sv-sidebar { width: 270px; }
    .sv-shell.is-rail .sv-sidebar-brand span:not(.sv-dot),
    .sv-shell.is-rail .sv-menu-item span,
    .sv-shell.is-rail .sv-nav-search { display: revert; }
    .sv-shell.is-rail .sv-menu-item { justify-content: flex-start; padding: 9px 14px; }
    .sv-shell.is-rail .sv-menu-group { font-size: 10.5px; padding: 16px 14px 6px; justify-content: flex-start; }

    .sv-drawer-backdrop { position: fixed; inset: 0; background: rgba(6,49,76,.45); z-index: 55;
        opacity: 0; pointer-events: none; transition: opacity .26s var(--sv-ease); }
    .sv-shell.is-drawer-open .sv-drawer-backdrop { opacity: 1; pointer-events: auto; }

    .sv-rail-toggle { display: none; }       /* recolher p/ ícones é só desktop */
    .sv-nav-toggle { display: inline-flex; } /* hambúrguer só no mobile */

    .sv-form-grid { grid-template-columns: 1fr; }
    .sv-col-2 { grid-column: span 1; }
    .sv-topbar { padding: 10px 14px; gap: 8px 10px; flex-wrap: wrap; }
    .sv-filial-select { max-width: 50vw; }
    .sv-user { font-size: 0; }
    .sv-user::before { font-size: 13px; }
}
@media (max-width: 560px) {
    .sv-main { padding: 16px 12px; }
    .sv-table { display: block; overflow-x: auto; white-space: nowrap; }
    .sv-page-head h1 { font-size: 21px; }
}

/* ===== Pedido de Venda — grid moderna ===== */
.sv-tabwrap { margin-top: 18px; }
.sv-ro { background: #f4f7f9; color: var(--sv-muted); font-weight: 600; }

/* Cabeçalho do pedido — número compacto + badge de status, sem estourar */
.sv-ped-cab { display: grid; grid-template-columns: minmax(0,1.2fr) minmax(0,1fr) minmax(0,1fr); gap: 14px; align-items: end; }
.sv-ped-cab > * { min-width: 0; }
.sv-ped-num-row { display: flex; align-items: center; gap: 10px; }
.sv-num-input { max-width: 120px; font-weight: 700; text-align: center; }
@media (max-width: 760px) { .sv-ped-cab { grid-template-columns: 1fr; } }

/* Badge de status (form + grid): faturado=verde, cancelado=vermelho, demais=azul/processando */
.sv-status { display: inline-flex; align-items: center; gap: 5px; padding: 3px 11px; border-radius: 999px;
    font: 700 12px "Public Sans", sans-serif; white-space: nowrap; line-height: 1.5; }
.sv-status i { width: 14px; height: 14px; }
.sv-status--ok { background: var(--sv-success-bg); color: var(--sv-success); }
.sv-status--danger { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-status--info { background: var(--sv-info-bg); color: var(--sv-teal-600); }

/* Grid de itens com rolagem horizontal em telas estreitas (não vaza a margem) */
.sv-grid-scroll { overflow-x: auto; }

/* Painel de itens expandido na grid de Entrada de Nota */
.sv-entrada-itens > td { background: #f7fafb !important; padding: 0 !important; }
.sv-subtable { width: 100%; border-collapse: collapse; margin: 0; }
.sv-subtable th, .sv-subtable td { padding: 6px 14px; font-size: 12.5px; border-bottom: 1px solid var(--sv-line); }
.sv-subtable thead th { background: #eef3f6; color: var(--sv-azul); text-align: left; }
.sv-subtable tbody tr:last-child td { border-bottom: none; }

/* Campo de desconto com toggle R$/% integrado */
.sv-desc-field { display: flex; align-items: stretch; border: 1px solid var(--sv-line); border-radius: 8px; overflow: hidden; background: #fff; }
.sv-desc-field .sv-item-descval { border: none !important; border-radius: 0 !important; width: 100%; min-width: 60px; text-align: right; padding-right: 6px; }
.sv-desc-field .sv-item-descval:focus { outline: none; box-shadow: none; }
.sv-desc-toggle { border: none; border-left: 1px solid var(--sv-line); background: var(--sv-bg); color: var(--sv-azul);
    font: 700 12px "Public Sans", sans-serif; cursor: pointer; padding: 0 10px; min-width: 38px; transition: background .12s var(--sv-ease); }
.sv-desc-toggle:hover { background: var(--sv-info-bg); }
.sv-desc-field:focus-within { border-color: var(--sv-teal); box-shadow: 0 0 0 2px rgba(4,160,170,.15); }

/* Linha com desconto acima do limite */
.sv-over-limit { background: var(--sv-warning-bg) !important; }
.sv-over-limit .sv-item-descval { color: var(--sv-danger); font-weight: 700; }

/* Card de inserção de item (campos grandes) */
.sv-item-card { background: linear-gradient(180deg,#f7fafb,#fff); border: 1px solid var(--sv-line);
    border-radius: 14px; padding: 16px 18px; margin-bottom: 16px; box-shadow: 0 1px 4px rgba(6,49,76,.05); }
.sv-item-card-grid { display: grid; grid-template-columns: 2.4fr 1.5fr .9fr 1.1fr 1.3fr; gap: 14px; align-items: end; }
.sv-item-card-grid .sv-field label { font-weight: 700; color: var(--sv-azul); }
.sv-item-card-grid select, .sv-item-card-grid input { height: 42px; font-size: 15px; }
.sv-item-card .sv-btn-add-item { margin-top: 14px; }
@media (max-width: 980px) { .sv-item-card-grid { grid-template-columns: 1fr 1fr; } .sv-card-produto { grid-column: span 2; } }
@media (max-width: 560px) { .sv-item-card-grid { grid-template-columns: 1fr; } .sv-card-produto { grid-column: span 1; } }

/* ===== Pedido de venda — mesa de pedido (claro, refinado) ===== */
/* fieldset wrapper tem min-width:min-content por padrão (estoura layout) — neutraliza */
.sv-form fieldset { min-width: 0; border: 0; margin: 0; padding: 0; }
.sv-pdv-grid { display: grid; grid-template-columns: minmax(0, 320px) minmax(0, 1fr); gap: 20px; align-items: start; }
.sv-pdv-grid > * { min-width: 0; }
.sv-pdv-grid select, .sv-pdv-cliente select { min-width: 0; max-width: 100%; }
@media (max-width: 1024px) { .sv-pdv-grid { grid-template-columns: 1fr; } }

/* Painel de busca de produto — card claro, faixa de marca no topo */
.sv-pdv-left { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 78px; min-width: 0; }
@media (max-width: 1024px) { .sv-pdv-left { position: static; } }
.sv-pdv-panel { background: var(--sv-surface); border: 1px solid var(--sv-line);
    border-radius: 16px; padding: 16px; box-shadow: var(--sv-shadow); overflow: hidden; }
.sv-pdv-ph { display: flex; align-items: center; gap: 8px; font: 800 11.5px "Public Sans", sans-serif;
    letter-spacing: .09em; text-transform: uppercase; color: #fff;
    background: linear-gradient(120deg, var(--sv-azul), var(--sv-teal)); padding: 12px 16px; margin: -16px -16px 16px; }
.sv-pdv-ph i { width: 16px; height: 16px; color: var(--sv-lima); }
.sv-pdv-panel .sv-field { margin-bottom: 12px; min-width: 0; }
.sv-pdv-panel .sv-field label { color: var(--sv-muted); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.sv-pdv-panel .sv-field input, .sv-pdv-panel select { width: 100%; height: 40px; border-radius: 9px;
    background: #fff; color: var(--sv-ink); border: 1px solid var(--sv-line); }
.sv-pdv-panel .sv-field input::placeholder { color: var(--sv-muted); }
.sv-pdv-panel .sv-field input:focus, .sv-pdv-panel select:focus { border-color: var(--sv-teal); box-shadow: 0 0 0 3px rgba(4,160,170,.16); }
.sv-pdv-addgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.sv-pdv-addgrid .sv-field:last-child { grid-column: span 2; }
.sv-pdv-addgrid .sv-desc-field { height: 40px; }
.sv-pdv-addgrid .sv-desc-field input { height: auto; }
.sv-pdv-add { width: 100%; justify-content: center; margin-top: 4px; height: 46px; font-size: 15px; }
.sv-pdv-left .sv-cli-card { margin: 6px 0 0; }

.sv-pdv-right { background: var(--sv-surface); border: 1px solid var(--sv-line); border-radius: 16px;
    padding: 18px 20px; box-shadow: var(--sv-shadow); min-width: 0; overflow: hidden; }
.sv-pdv-cart-head { display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding-bottom: 12px; border-bottom: 1px solid var(--sv-line); margin-bottom: 10px; font-weight: 700; color: var(--sv-ink); }
.sv-pdv-cart-head i { width: 18px; height: 18px; color: var(--sv-teal-600); vertical-align: -3px; }

/* Stepper de quantidade */
.sv-qty { display: inline-flex; align-items: stretch; border: 1px solid var(--sv-line); border-radius: 8px; overflow: hidden; background: #fff; }
.sv-qty .sv-item-qty { width: 50px; border: none !important; text-align: center; border-radius: 0 !important; box-shadow: none !important; }
.sv-qbtn { border: none; background: var(--sv-bg); color: var(--sv-azul); width: 28px; cursor: pointer; font: 700 16px/1 "Public Sans", sans-serif; }
.sv-qbtn:hover { background: var(--sv-info-bg); color: var(--sv-teal-600); }

.sv-pdv-summary { margin-top: 14px; margin-left: auto; max-width: 360px; display: flex; flex-direction: column; gap: 4px; font-size: 13.5px; color: var(--sv-muted); }
.sv-pdv-sumrow { display: flex; align-items: baseline; justify-content: space-between; gap: 18px; }
.sv-pdv-summary b { color: var(--sv-text); font-variant-numeric: tabular-nums; white-space: nowrap; }
.sv-pdv-summary b::before { content: "R$ "; font-size: 11px; opacity: .6; font-weight: 600; }
.sv-pdv-summary .sv-neg { color: var(--sv-danger); }
.sv-pdv-total { margin-top: 10px; margin-left: auto; max-width: 360px; display: flex; align-items: center; justify-content: space-between; gap: 14px;
    background: linear-gradient(120deg, var(--sv-azul-900), var(--sv-azul)); color: #fff; padding: 14px 20px; border-radius: 14px; }
.sv-pdv-total span { font: 700 12px "Public Sans", sans-serif; letter-spacing: .14em; opacity: .82; }
.sv-pdv-total b { font: 800 24px "Bricolage Grotesque", sans-serif; font-variant-numeric: tabular-nums; white-space: nowrap; line-height: 1.1; }
.sv-pdv-total b::before { content: "R$ "; font-size: 14px; opacity: .8; font-weight: 700; }

/* Cliente — card full-width no topo (select + endereço lado a lado) */
.sv-pdv-cliente { padding: 16px 18px; margin-bottom: 18px; }
.sv-pdv-cliente-sel { max-width: 100%; min-width: 0; margin: 0; }
.sv-pdv-cliente-sel select { width: 100%; text-overflow: ellipsis; }
.sv-pdv-cliente-sel > label { display: flex; align-items: center; gap: 6px; }
.sv-pdv-cliente-sel > label i { width: 15px; height: 15px; color: var(--sv-teal-600); }
.sv-pdv-cliente .sv-cli-card { margin: 12px 0 0; }
.sv-pdv-cliente .sv-cli-lines { display: flex; flex-wrap: wrap; gap: 4px 20px; font-size: 13px; min-width: 0; }
.sv-pdv-cliente .sv-cli-lines > div { white-space: normal; word-break: break-word; }
.sv-pdv-cliente .sv-cli-lines > div b { color: var(--sv-azul); font-weight: 700; }
@media (max-width: 760px) { .sv-pdv-cliente-sel { max-width: 100%; } }

/* Buscar produto — barra horizontal full-width */
.sv-pdv-busca { padding: 16px; overflow: hidden; margin-bottom: 16px; }
.sv-pdv-busca-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }
.sv-pdv-busca-row .sv-field { margin: 0; min-width: 0; }
.sv-pdv-busca-row .sv-field label { color: var(--sv-muted); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.sv-pdv-busca-row .sv-field input, .sv-pdv-busca-row .sv-field select { width: 100%; height: 40px; border-radius: 9px; }
.sv-pdv-busca-row .f-prod { flex: 3 1 180px; }
.sv-pdv-busca-row .f-local { flex: 1 1 140px; }
.sv-pdv-busca-row .f-qty { flex: 0 1 84px; }
.sv-pdv-busca-row .f-preco { flex: 0 1 116px; }
.sv-pdv-busca-row .f-desc { flex: 0 1 138px; }
.sv-pdv-busca-row .f-desc .sv-desc-field { height: 40px; }
.sv-pdv-busca-row .f-desc .sv-desc-field input { height: auto; }
.sv-pdv-busca-row .sv-pdv-add { flex: 0 0 auto; width: auto; height: 40px; margin: 0; }
@media (max-width: 700px) {
    .sv-pdv-busca-row .f-prod, .sv-pdv-busca-row .f-local, .sv-pdv-busca-row .sv-pdv-add { flex: 1 1 100%; }
}

/* Card de abas (Itens / Pagamento / Detalhes) */
.sv-pdv-tabs-card { margin-top: 0; padding: 16px 18px; }
.sv-pdv-tabs-card .sv-tabs { margin-bottom: 16px; }
.sv-tab-badge { background: var(--sv-bg); color: var(--sv-azul); border-radius: 999px; padding: 1px 8px; font: 700 11px "Public Sans", sans-serif; margin-left: 4px; }
.sv-tab.is-active .sv-tab-badge { background: var(--sv-teal); color: #fff; }
.sv-pdv-tabs-card .sv-pdv-cart-head { border-bottom: none; padding-bottom: 0; margin-bottom: 12px; justify-content: flex-end; }

/* Rodapé de ações (sempre visível, abaixo das abas) */
.sv-pdv-footer { margin-top: 16px; border-top: 1px solid var(--sv-line); padding-top: 16px; }

/* Carrinho = lista de cards (produto grande em cima; local/unit/desconto embaixo) */
.sv-cart-list { display: flex; flex-direction: column; gap: 10px; }
.sv-cart-list .sv-item-row { border: 1px solid var(--sv-line); border-radius: 13px; padding: 11px 13px; background: #fff; transition: box-shadow .12s var(--sv-ease), border-color .12s var(--sv-ease); }
.sv-cart-list .sv-item-row:hover { box-shadow: 0 4px 14px rgba(6,49,76,.08); border-color: #cfdde4; }
.sv-cart-list .sv-item-row.sv-over-limit { background: var(--sv-warning-bg); border-color: #e8cf86; }
/* Linha principal = grid estável: seq · produto · qtd · total · remover */
.sv-cart-main { display: grid; grid-template-columns: 24px minmax(0, 1fr) auto 132px 32px; gap: 12px; align-items: center; }
.sv-cart-main .sv-seq { width: 24px; height: 24px; border-radius: 7px; background: var(--sv-bg); color: var(--sv-muted); font: 700 11px/24px "Public Sans", sans-serif; text-align: center; }
.sv-cart-prod { min-width: 0; }
.sv-cart-prod .sv-item-produto { width: 100%; border: 1px solid transparent; background: transparent; font-weight: 700; color: var(--sv-ink); font-size: 14px; padding: 7px 6px; text-overflow: ellipsis; }
.sv-cart-prod .sv-item-produto:hover, .sv-cart-prod .sv-item-produto:focus { border-color: var(--sv-line); background: #fff; }
.sv-cart-total { width: 132px; }
.sv-cart-total .sv-item-total { width: 100%; height: 38px; text-align: right; font-weight: 800; color: var(--sv-azul); background: #f4f7f9; font-variant-numeric: tabular-nums; }
/* Sub-linha = flex (preço / desconto / local / cfop) sempre visíveis */
.sv-cart-sub { display: flex; flex-wrap: wrap; gap: 12px; align-items: end;
    margin-top: 10px; padding: 10px 0 2px 36px; border-top: 1px dashed var(--sv-line); }
.sv-cart-sub > label { display: flex; flex-direction: column; gap: 4px; min-width: 0; font: 700 10px "Public Sans", sans-serif; text-transform: uppercase; letter-spacing: .04em; color: var(--sv-muted); }
.sv-cart-sub > label.sv-lbl-preco, .sv-cart-sub > label.sv-lbl-desc { flex: 1 1 130px; }
.sv-cart-sub > label.sv-lbl-local { flex: 1 1 200px; }
.sv-cart-sub > label.sv-lbl-cfop { flex: 0 0 90px; }
.sv-cart-sub .sv-item-local, .sv-cart-sub .sv-item-preco, .sv-cart-sub .sv-item-cfop, .sv-cart-sub .sv-desc-field { width: 100%; }
.sv-cart-sub .sv-item-preco { text-align: right; font-variant-numeric: tabular-nums; }
.sv-cart-sub input, .sv-cart-sub select, .sv-cart-sub .sv-desc-field { height: 36px; }
.sv-cart-sub .sv-desc-field input { height: auto; }
@media (max-width: 560px) {
    .sv-cart-main { grid-template-columns: 24px minmax(0, 1fr) 32px; row-gap: 8px; }
    .sv-cart-prod { grid-column: 2 / 4; }
    .sv-cart-main .sv-qty { grid-column: 2; }
    .sv-cart-total { width: 100%; grid-column: 3 / 4; grid-row: 3; justify-self: end; }
    .sv-cart-sub { grid-template-columns: 1fr 1fr; padding-left: 0; }
    .sv-cart-sub > label:first-child { grid-column: span 2; }
}

.sv-pdv-pay { margin-top: 16px; border-top: 1px solid var(--sv-line); padding-top: 14px; }
.sv-pdv-actions { display: flex; gap: 12px; justify-content: flex-end; align-items: center; margin-top: 18px; }
.sv-btn-finalizar { display: inline-flex; align-items: center; gap: 9px; padding: 13px 28px; border: none; border-radius: 12px; cursor: pointer;
    background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); color: #fff; font: 800 15px "Public Sans", sans-serif;
    box-shadow: 0 4px 14px rgba(4,160,170,.32); transition: transform .12s var(--sv-ease), box-shadow .12s var(--sv-ease); }
.sv-btn-finalizar:hover { transform: translateY(-1px); box-shadow: 0 7px 20px rgba(4,160,170,.42); }
.sv-btn-finalizar i { width: 19px; height: 19px; }

.sv-pdv-mais { margin-top: 16px; padding: 14px 18px; }
.sv-pdv-mais > summary { cursor: pointer; font-weight: 700; color: var(--sv-azul); display: flex; align-items: center; gap: 8px; list-style: none; }
.sv-pdv-mais > summary::-webkit-details-marker { display: none; }
.sv-pdv-mais > summary i { width: 16px; height: 16px; }

/* Botão Adicionar item — destacado */
.sv-btn-add-item { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; border-radius: 10px;
    background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); color: #fff; border: none; cursor: pointer;
    font: 700 14px "Public Sans", sans-serif; box-shadow: 0 3px 10px rgba(4,160,170,.30); transition: transform .12s var(--sv-ease), box-shadow .12s var(--sv-ease); }
.sv-btn-add-item:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(4,160,170,.40); }
.sv-btn-add-item i { width: 18px; height: 18px; }

/* Botão Cancelar pedido — formato distinto (ghost danger, tracejado) */
.sv-btn-cancelar { display: inline-flex; align-items: center; gap: 7px; padding: 8px 16px; border-radius: 999px;
    background: transparent; color: var(--sv-danger); border: 1.5px dashed var(--sv-danger);
    font: 600 13px "Public Sans", sans-serif; cursor: pointer; transition: all .15s var(--sv-ease); }

/* ===== Barra de ações fixa (sticky) no topo do form ===== */
.sv-actionbar{position:sticky;top:0;z-index:20;display:flex;gap:.5rem;align-items:center;
  background:var(--sv-surface,#fff);padding:.6rem .25rem;margin:-.25rem 0 1rem;
  border-bottom:1px solid var(--sv-line,#E1E9EE);box-shadow:0 2px 6px rgba(0,0,0,.04)}
.sv-actionbar .sv-actionbar-title{font-weight:700;color:var(--sv-ink,#0E2A3D);margin-right:auto}
.sv-btn-cancelar:hover { background: var(--sv-danger); color: #fff; border-style: solid; }
.sv-btn-cancelar i { width: 16px; height: 16px; }

/* Previsão de parcelas (aba Pagamento) */
.sv-parcelas { margin: 14px 0; max-width: 440px; }
.sv-parcelas h4 { display: flex; align-items: center; gap: 7px; margin: 0 0 8px; font-size: 14px; color: var(--sv-azul); }
.sv-parcelas h4 i { width: 16px; height: 16px; }
.sv-parcelas-tbl td, .sv-parcelas-tbl th { padding: 6px 10px; }
.sv-log-val { font-size: 11px; color: var(--sv-muted); font-family: "JetBrains Mono", monospace; word-break: break-all; }
.sv-desc-wrap .sv-item-descval { width: 74px; }
.sv-desc-wrap .sv-item-desctipo { width: 54px; }

.sv-grid-pedido { width: 100%; border-collapse: separate; border-spacing: 0; background: var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: 12px; overflow: hidden; }
.sv-grid-pedido thead th { background: linear-gradient(180deg,#f7fafb,#eef3f6); color: var(--sv-ink);
    font: 700 12px "Public Sans", sans-serif; text-transform: uppercase; letter-spacing: .03em;
    padding: 11px 10px; text-align: left; border-bottom: 2px solid var(--sv-line); }
.sv-grid-pedido tbody td { padding: 7px 10px; border-bottom: 1px solid var(--sv-line); vertical-align: middle; }
.sv-grid-pedido tbody tr:last-child td { border-bottom: none; }
.sv-grid-pedido tbody tr:hover { background: #f8fbfc; }
.sv-grid-pedido .sv-seq { color: var(--sv-muted); font-weight: 700; text-align: center; }
.sv-grid-pedido select, .sv-grid-pedido input { width: 100%; }
.sv-grid-pedido .sv-item-total { background: #f4f7f9; font-weight: 700; text-align: right; }
.sv-icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px;
    border: 1px solid var(--sv-line); background: #fff; border-radius: 8px; cursor: pointer; color: var(--sv-danger);
    transition: all .15s var(--sv-ease); }
.sv-icon-btn:hover { background: var(--sv-danger-bg); border-color: var(--sv-danger); }
.sv-icon-btn i { width: 16px; height: 16px; }

.sv-totais { margin: 16px 0 4px auto; max-width: 320px; background: var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: 12px; padding: 12px 16px; }
.sv-totais-row { display: flex; justify-content: space-between; padding: 5px 0; color: var(--sv-text); font-size: 14px; }
.sv-totais-row .sv-neg { color: var(--sv-danger); }
.sv-totais-total { border-top: 2px solid var(--sv-line); margin-top: 6px; padding-top: 10px; font-size: 18px; font-weight: 800; color: var(--sv-azul); }

/* Cartão de endereço do cliente no pedido */
.sv-cli-card { margin: 14px 0 4px; padding: 12px 16px; background: var(--sv-info-bg);
    border: 1px solid #bfe6e9; border-left: 4px solid var(--sv-teal); border-radius: 10px; }
.sv-cli-head { display: flex; align-items: center; gap: 8px; font-weight: 700; color: var(--sv-azul); margin-bottom: 4px; }
.sv-cli-head i { width: 17px; height: 17px; }
.sv-cli-lines { color: var(--sv-text); font-size: 13px; line-height: 1.55; }

/* Banner inline (substitui mensagens "!") */
.sv-banner { display: flex; gap: 12px; align-items: flex-start; padding: 13px 16px; border-radius: 10px;
    margin-bottom: 16px; font-size: 14px; }
.sv-banner i { width: 20px; height: 20px; flex: none; margin-top: 1px; }
.sv-banner--warn { background: var(--sv-warning-bg); color: #8a6d00; border: 1px solid #e8cf86; }
.sv-banner--info { background: var(--sv-info-bg); color: var(--sv-azul); border: 1px solid #bfe6e9; }

/* ===== KPI cards (Dashboard Financeiro) ===== */
.sv-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.sv-kpi { display: flex; gap: 14px; align-items: center; padding: 16px 18px; background: var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: 14px; text-decoration: none; color: inherit;
    border-left: 5px solid var(--sv-cinza); transition: transform .15s var(--sv-ease), box-shadow .15s var(--sv-ease); }
a.sv-kpi:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(6,49,76,.10); }
.sv-kpi-ico { display: flex; align-items: center; justify-content: center; width: 46px; height: 46px;
    border-radius: 12px; background: var(--sv-bg); flex: none; }
.sv-kpi-ico i { width: 24px; height: 24px; }
.sv-kpi-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.sv-kpi-lbl { font-size: 12px; text-transform: uppercase; letter-spacing: .03em; color: var(--sv-muted); font-weight: 700; }
.sv-kpi-val { font: 800 20px "Bricolage Grotesque", sans-serif; color: var(--sv-ink); }
.sv-kpi-sub { font-size: 12px; color: var(--sv-muted); }
.sv-kpi--ok { border-left-color: var(--sv-success); } .sv-kpi--ok .sv-kpi-ico { background: var(--sv-success-bg); color: var(--sv-success); }
.sv-kpi--danger { border-left-color: var(--sv-danger); } .sv-kpi--danger .sv-kpi-ico { background: var(--sv-danger-bg); color: var(--sv-danger); }
.sv-kpi--warn { border-left-color: var(--sv-warning); } .sv-kpi--warn .sv-kpi-ico { background: var(--sv-warning-bg); color: var(--sv-warning); }
.sv-kpi--info { border-left-color: var(--sv-info); } .sv-kpi--info .sv-kpi-ico { background: var(--sv-info-bg); color: var(--sv-info); }

/* ===== PWA: safe-area (notch) em modo standalone ===== */
@media (display-mode: standalone) {
    .sv-topbar { padding-top: max(12px, env(safe-area-inset-top)); }
    .sv-main { padding-bottom: max(26px, env(safe-area-inset-bottom)); }
    .sv-sidebar { padding-top: max(0px, env(safe-area-inset-top)); }
}

/* ===== Log do Sistema: tabela de detalhe JSON (modal SV.jsonDetalhe) ===== */
.sv-json-tbl{width:100%;border-collapse:collapse;font-size:13px}
.sv-json-tbl th,.sv-json-tbl td{border:1px solid #e3e8ee;padding:.35rem .5rem;text-align:left;vertical-align:top}
.sv-json-tbl thead th{background:#f3f6f9;color:#15324b}
.sv-json-tbl tr.sv-json-mud td{background:#fff7e6}

/* ===== Semaforo de vencimento (grid Contas a Pagar) ===== */
.sv-dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle}
.sv-dot--ok{background:var(--sv-success)}
.sv-dot--warn{background:var(--sv-warning)}
.sv-dot--danger{background:var(--sv-danger)}
.sv-dot--muted{background:var(--sv-cinza)}
.sv-dot--partial{background:var(--sv-roxo)}
.sv-legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:12px;color:var(--sv-muted);margin:.25rem 0 .75rem}
.sv-legend span{display:inline-flex;align-items:center;gap:.35rem}

/* ======================================================================= */
/* ===== PDV / Pedido de Venda — refino UIX "Sales Desk" ================= */
/* Escopado em #form-pedido / .sv-pdv-* / .sv-cart-* — tokens e rgba de    */
/* marca apenas (dark-safe). NÃO afeta outras telas do ERP.               */
/* ======================================================================= */

/* Entrada encenada das seções ao abrir o pedido (stagger) */
@media (prefers-reduced-motion: no-preference) {
    #form-pedido .sv-pdv-cliente { animation: sv-rise .42s var(--sv-ease) both; }
    #form-pedido .sv-pdv-busca   { animation: sv-rise .42s var(--sv-ease) .06s both; }
    .sv-pdv-tabs-card            { animation: sv-rise .42s var(--sv-ease) .12s both; }
}

/* Cliente — bloco de identidade com trilho de acento e leve atmosfera */
.sv-pdv-cliente { position: relative; overflow: hidden;
    background: linear-gradient(180deg, rgba(4,160,170,.045), transparent 130px), var(--sv-surface); }
.sv-pdv-cliente::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 3px;
    background: linear-gradient(180deg, var(--sv-teal), var(--sv-azul)); }
.sv-pdv-cliente-sel > label { color: var(--sv-azul); }

/* Busca — "command bar" com elevação ao focar */
.sv-pdv-busca { background: linear-gradient(180deg, rgba(6,49,76,.022), transparent 64px), var(--sv-surface);
    transition: box-shadow .2s var(--sv-ease), border-color .2s var(--sv-ease); }
.sv-pdv-busca:focus-within { border-color: var(--sv-teal); box-shadow: 0 12px 32px rgba(6,49,76,.11); }
.sv-pdv-busca .sv-pdv-ph { color: var(--sv-azul); }
.sv-pdv-busca .sv-pdv-ph i { color: var(--sv-teal-600); }

/* Abas — indicador ativo refinado */
.sv-pdv-tabs-card .sv-tab { border-radius: 9px 9px 0 0; transition: color .15s var(--sv-ease), background .15s var(--sv-ease); }
.sv-pdv-tabs-card .sv-tab:hover { background: rgba(4,160,170,.06); }
.sv-pdv-tabs-card .sv-tab.is-active { background: linear-gradient(180deg, rgba(4,160,170,.08), transparent); }

/* Linha do carrinho — trilho de acento ao hover/foco + selo refinado */
.sv-cart-list .sv-item-row { position: relative; overflow: hidden; }
.sv-cart-list .sv-item-row::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
    background: linear-gradient(180deg, var(--sv-teal), var(--sv-azul));
    transform: scaleY(0); transform-origin: top; opacity: 0;
    transition: transform .18s var(--sv-ease), opacity .18s var(--sv-ease); }
.sv-cart-list .sv-item-row:hover::before,
.sv-cart-list .sv-item-row:focus-within::before { transform: scaleY(1); opacity: 1; }
.sv-cart-list .sv-item-row:focus-within { border-color: var(--sv-teal); box-shadow: 0 6px 18px rgba(6,49,76,.10); }
.sv-cart-list .sv-item-row.sv-over-limit::before {
    background: linear-gradient(180deg, var(--sv-warning), #d98a00); transform: scaleY(1); opacity: 1; }
.sv-cart-main .sv-seq { background: var(--sv-info-bg); color: var(--sv-teal-600); font-weight: 800; }
.sv-cart-total .sv-item-total { background: var(--sv-bg); border-color: transparent; border-radius: 9px;
    box-shadow: inset 0 0 0 1px rgba(4,160,170,.12); }

/* ===== Painel de faturamento (resumo + TOTAL) — o herói ===== */
.sv-pdv-billing { margin: 18px 0 4px auto; max-width: 384px; position: relative; overflow: hidden;
    background: radial-gradient(130% 100% at 100% 0, rgba(4,160,170,.07), transparent 60%), var(--sv-surface);
    border: 1px solid var(--sv-line); border-radius: 16px; padding: 16px 20px 18px;
    box-shadow: 0 12px 34px rgba(6,49,76,.09); }
.sv-pdv-billing::before { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 3px;
    background: linear-gradient(90deg, var(--sv-teal), var(--sv-azul) 55%, var(--sv-lima)); }
.sv-pdv-billing-head { display: flex; align-items: center; gap: 7px; margin-bottom: 12px;
    font: 800 11px "Public Sans", sans-serif; text-transform: uppercase; letter-spacing: .12em; color: var(--sv-muted); }
.sv-pdv-billing-head i { width: 15px; height: 15px; color: var(--sv-teal-600); }
.sv-pdv-billing .sv-pdv-summary { margin: 0; max-width: none; }
.sv-pdv-billing .sv-pdv-sumrow { padding: 3px 0; }
.sv-pdv-billing .sv-pdv-total { margin: 12px 0 0; max-width: none; padding-top: 14px; border-top: 1px dashed var(--sv-line); }
.sv-pdv-billing .sv-pdv-total b { color: #fff; }

/* ======================================================================= */
/* ===== Importar XML (NF-e) — refino UIX (coluna Ação alinhada) ========= */
/* Escopado em .sv-imp-* — não afeta outras telas. JS preserva adjacência   */
/* select.secao + .js-add-secao (previousElementSibling) — só CSS aqui.    */
/* ======================================================================= */

/* Card do fornecedor — trilho de acento + atmosfera, igual aos demais */
.sv-imp-fornec { position: relative; overflow: hidden;
    background: linear-gradient(180deg, rgba(4,160,170,.045), transparent 120px), var(--sv-surface);
    animation: sv-rise .4s var(--sv-ease) both; }
.sv-imp-fornec::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 3px;
    background: linear-gradient(180deg, var(--sv-teal), var(--sv-azul)); }
.sv-imp-fornec .sv-cli-head { color: var(--sv-azul); }
.sv-imp-fornec .sv-cli-head i { color: var(--sv-teal-600); }

/* Coluna Ação — cluster alinhado: [ação ▾]  [seção ▾][+]  [grupo ▾][+] */
.sv-imp-acao { white-space: nowrap; }
.sv-imp-acao > .acao { height: 34px; min-width: 112px; border-radius: 8px; vertical-align: middle; }
.sv-imp-acao .vinc-wrap, .sv-imp-acao .cad-wrap { display: inline-flex; align-items: center; margin-left: 10px; vertical-align: middle; }
.sv-imp-acao .vinc-wrap select { height: 34px; border-radius: 8px; }
.sv-imp-acao .cad-wrap select { height: 34px; min-width: 134px; border-radius: 8px 0 0 8px; }
.sv-imp-acao .cad-wrap select.grupo { margin-left: 12px; }
.sv-imp-acao .cad-wrap .sv-icon-btn { width: 34px; height: 34px; border-radius: 0 8px 8px 0; margin-left: -1px;
    border-color: var(--sv-line); background: var(--sv-bg); }
.sv-imp-acao .cad-wrap .sv-icon-btn:hover { background: var(--sv-info-bg); border-color: var(--sv-teal); }
.sv-imp-acao .cad-wrap .sv-icon-btn i { width: 15px; height: 15px; }

/* ======================================================================= */
/* ===== MDF-e — stepper guiado + blocos (escopado .sv-mdfe / .sv-steps) == */
/* Reaproveita tokens de marca e .sv-tabpane. Não afeta outras telas.      */
/* ======================================================================= */
.sv-steps { display: flex; align-items: flex-start; gap: 0; margin: 4px 0 20px; flex-wrap: nowrap; overflow-x: auto; }
.sv-step { flex: 1 1 0; min-width: 92px; display: flex; flex-direction: column; align-items: center; gap: 7px;
    position: relative; padding: 0 6px; cursor: default; }
.sv-step::before { content: ""; position: absolute; top: 16px; left: -50%; width: 100%; height: 2px;
    background: var(--sv-line); z-index: 0; }
.sv-step:first-child::before { display: none; }
.sv-step .sv-step-no { position: relative; z-index: 1; width: 34px; height: 34px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center; background: var(--sv-surface);
    border: 2px solid var(--sv-line); color: var(--sv-muted); font: 800 14px "Bricolage Grotesque", sans-serif;
    transition: all .2s var(--sv-ease); }
.sv-step .sv-step-no svg { width: 16px; height: 16px; }
.sv-step .sv-step-lbl { font-size: 12px; font-weight: 600; color: var(--sv-muted); text-align: center; line-height: 1.25; }
.sv-step.is-active .sv-step-no { border-color: var(--sv-teal); color: #fff;
    background: linear-gradient(135deg, var(--sv-teal), var(--sv-azul)); box-shadow: 0 2px 8px rgba(4,160,170,.32); }
.sv-step.is-active .sv-step-lbl { color: var(--sv-ink); }
.sv-step.is-done .sv-step-no { border-color: var(--sv-success); background: var(--sv-success-bg); color: var(--sv-success); }
.sv-step.is-done::before { background: var(--sv-success); }
.sv-step.is-done .sv-step-lbl { color: var(--sv-text); }

.sv-wizard-actions { display: flex; align-items: center; gap: 10px; margin-top: 18px; padding-top: 16px;
    border-top: 1px solid var(--sv-line); }
.sv-wizard-actions .sv-spacer { margin-left: auto; }

/* Campo inválido (validação client-side do wizard) */
.sv-field.is-invalid input, .sv-field.is-invalid select, .sv-field.is-invalid textarea { border-color: var(--sv-danger); background: var(--sv-danger-bg); }
.sv-field-err { color: var(--sv-danger); font-size: 12px; font-weight: 600; margin-top: 4px; display: none; }
.sv-field.is-invalid .sv-field-err { display: block; }

/* Chips de UF (percurso) */
.sv-chip { display: inline-flex; align-items: center; gap: 5px; font: 700 12px "Public Sans", sans-serif;
    background: var(--sv-info-bg); color: var(--sv-teal-600); padding: 3px 11px; border-radius: 999px; }
.sv-chips { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

/* Revisão final do wizard (chave/valor compacto) */
.sv-review { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px 18px; }
.sv-review-cell { display: flex; flex-direction: column; gap: 1px; }
.sv-review-k { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--sv-muted); }
.sv-review-v { font-size: 14px; font-weight: 600; color: var(--sv-ink); overflow-wrap: anywhere; }

/* Bloco de seção em Detalhes (cabeçalho com ícone) — reusa .sv-card */
.sv-block-title { display: flex; align-items: center; gap: 8px; margin: 0 0 12px; font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .04em; color: var(--sv-muted); }
.sv-block-title svg { width: 16px; height: 16px; color: var(--sv-teal-600); }
@media (max-width: 760px) { .sv-step .sv-step-lbl { font-size: 0; } .sv-step .sv-step-no { width: 30px; height: 30px; } }

/* =====================================================================
   AJUDA POR TELA — conteúdo rico (botão "?" e editor admin)
   ===================================================================== */
/* Tipografia do conteúdo de ajuda (renderizado no popup e no preview) */
.sv-help-content { text-align: left; color: var(--sv-text); font-size: 14px; line-height: 1.62; }
.sv-help-content h2 { font-family: "Bricolage Grotesque", sans-serif; color: var(--sv-azul); font-size: 18px; margin: 0 0 10px; }
.sv-help-content h3 { font-family: "Bricolage Grotesque", sans-serif; color: var(--sv-azul); font-size: 15px;
    margin: 16px 0 6px; padding-bottom: 4px; border-bottom: 1px solid var(--sv-line); }
.sv-help-content h4 { color: var(--sv-teal-600); font-size: 13.5px; margin: 12px 0 4px; }
.sv-help-content p { margin: 6px 0; }
.sv-help-content ul, .sv-help-content ol { margin: 6px 0; padding-left: 22px; }
.sv-help-content li { margin: 4px 0; }
.sv-help-content strong { color: var(--sv-ink); }
.sv-help-content code { background: var(--sv-info-bg); color: var(--sv-azul); padding: 1px 5px; border-radius: 5px;
    font-family: ui-monospace, Consolas, monospace; font-size: 12.5px; }
.sv-help-content table { width: 100%; border-collapse: collapse; margin: 8px 0; font-size: 13px; }
.sv-help-content th, .sv-help-content td { border: 1px solid var(--sv-line); padding: 6px 8px; text-align: left; }
.sv-help-content th { background: var(--sv-info-bg); }

/* Caixas de destaque dentro da ajuda */
.sv-help-content .help-alert, .sv-help-content .help-tip, .sv-help-content .help-warning {
    border-radius: 10px; padding: 10px 13px; margin: 10px 0; border: 1px solid transparent; }
.sv-help-content .help-alert   { background: var(--sv-info-bg);    color: var(--sv-azul); border-color: #bfe6e9; }
.sv-help-content .help-tip     { background: var(--sv-success-bg, #e8f7ee); color: #1f7a43; border-color: #b6e3c6; }
.sv-help-content .help-warning { background: var(--sv-warning-bg);  color: #8a6d00; border-color: #e8cf86; }
.sv-help-content .help-alert p, .sv-help-content .help-tip p, .sv-help-content .help-warning p { margin: 0; }
.sv-help-content .help-tip::before     { content: "💡 "; }
.sv-help-content .help-warning::before { content: "⚠️ "; }

/* Popup de ajuda (SweetAlert) — limita altura e habilita rolagem */
.sv-help-swal { max-height: 68vh; overflow-y: auto; }

/* Banner verde (sucesso/info positiva) — complementa .sv-banner */
.sv-banner--ok { background: var(--sv-success-bg, #e8f7ee); color: #1f7a43; border: 1px solid #b6e3c6; }

/* Editor de ajuda: textarea + preview lado a lado */
.sv-help-edit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: stretch; }
@media (max-width: 980px) { .sv-help-edit-grid { grid-template-columns: 1fr; } }

/* Etiqueta pequena e dica de campo (usadas no editor e listagens) */
.sv-tag { display: inline-block; font-size: 11px; font-weight: 700; color: var(--sv-muted);
    background: var(--sv-info-bg); border-radius: 999px; padding: 1px 9px; }
.sv-hint { display: block; margin-top: 4px; font-size: 12px; color: var(--sv-muted); }
.sv-hint code { font-size: 11.5px; }
.sv-form-section {
    font-family: "Bricolage Grotesque", sans-serif; font-size: 14px; font-weight: 700; color: var(--sv-ink);
    margin: 22px 0 10px; padding-bottom: 6px; border-bottom: 1px solid var(--sv-line);
}
.sv-switch { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 14px; }
.sv-switch input { width: 16px; height: 16px; }

/* ── Lookup/autocomplete dropdown (picker de veículo/motorista no MDF-e) ── */
.sv-lookup-sug {
    position: absolute; left: 0; right: 0; top: calc(100% + 2px); z-index: 40;
    max-height: 40vh; overflow-y: auto;
    background: var(--sv-surface); border: 1px solid var(--sv-line);
    border-radius: var(--sv-r-lg); box-shadow: var(--sv-shadow-lg);
    padding: 4px;
}
.sv-lookup-item {
    padding: 10px 14px; border-radius: var(--sv-r-sm); cursor: pointer;
    font-size: 14px; color: var(--sv-ink); border: 1px solid transparent;
}
.sv-lookup-item:hover {
    background: var(--sv-info-bg); border-color: var(--sv-teal);
}

