/* CSS extraído do monitoramento.html (phase 2 do refactor)
   Contém só regras de views (.mon-section, .mon-panel, .aq-*, .cc-*, .rede-*, modais).
   Layout/sidebar/body globais ficam fora — index.html já tem v2-sidebar. */



        body:not(.theme-dark) {
            --primary: #444ce7;
            --primary-dim: rgba(68,76,231,0.10);
            --primary-glow: rgba(68,76,231,0.20);
            --gradient: linear-gradient(135deg, #323fa2 0%, #444ce7 100%);
            --bg-root: #fbfbfb;
            --bg-sidebar: #fbfbfb;
            --bg-card: #ffffff;
            --bg-card-hover: #f5f5f5;
            --bg-input: #f5f5f5;
            --bg-elevated: #efefef;
            --border: #e5e5e5;
            --border-default: #e5e5e5;
            --text-title: #0a0a0a;
            --text-primary: #171717;
            --text-secondary: #525252;
            --text-muted: #667085;
            --text-tertiary: #8c8c8c;
            --success: #16a34a;
            --error: #e40014;
            --warning: #d97706;
            --info: #155dfc;
            --danger: #e40014;
            --cyan: #155dfc;
            --accent: #444ce7;
        }


        * { box-sizing: border-box; }

        body, .btn, input, select, textarea {
            font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
        }

        [data-lucide] { display:inline-block; vertical-align:middle; flex-shrink:0; }

        .lc    { width:14px; height:14px; }

        .lc-nav{ width:16px; height:16px; }

        .lc-lg { width:30px; height:30px; }


        body {
            margin: 0;
            background: var(--bg-root);
            color: var(--text-primary);
            min-height: 100vh;
        }


        /* ── Main ─────────────────────────────────────── */
        .mon-main { padding: 22px 100px; min-width: 0; }

        .mon-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 22px; flex-wrap: wrap; }

        .mon-eyebrow { font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }

        .mon-title { font-size: 26px; font-weight: 900; color: var(--text-title); letter-spacing: -0.8px; margin: 4px 0 2px; }

        .mon-subtitle { font-size: 13px; color: var(--text-muted); }


        .mon-status-pill {
            display: inline-flex; align-items: center; gap: 6px;
            background: var(--bg-card); border: 1px solid var(--border);
            border-radius: 99px; padding: 5px 12px;
            font-size: 11px; font-weight: 700; color: var(--text-secondary);
        }

        .mon-pulse {
            width: 8px; height: 8px; border-radius: 50%; background: var(--success);
            box-shadow: 0 0 0 0 rgba(74,222,128,0.5);
            animation: monPulse 2s infinite;
        }

        @keyframes monPulse {
            0%   { box-shadow: 0 0 0 0 rgba(74,222,128,0.5); }
            70%  { box-shadow: 0 0 0 8px rgba(74,222,128,0); }
            100% { box-shadow: 0 0 0 0 rgba(74,222,128,0); }
        }


        /* KPI Cards */
        .mon-kpi-grid {
            display: grid; grid-template-columns: repeat(4, 1fr);
            gap: 12px; margin-bottom: 18px;
        }

        .mon-kpi-card {
            background: var(--bg-card); border: 1px solid var(--border);
            border-radius: var(--r-lg); padding: 16px;
            display: flex; flex-direction: column; gap: 6px;
            position: relative; overflow: hidden;
            transition: var(--t);
        }

        .mon-kpi-card:hover { border-color: rgba(89,107,255,0.30); }

        .mon-kpi-label {
            font-size: 11px; font-weight: 700; color: var(--text-muted);
            text-transform: uppercase; letter-spacing: 0.6px;
            display: flex; align-items: center; gap: 6px;
        }

        .mon-kpi-value { font-size: 26px; font-weight: 900; color: var(--text-title); letter-spacing: -1px; }

        .mon-kpi-sub { font-size: 11px; color: var(--text-muted); }

        .mon-kpi-card.accent-error  .mon-kpi-value { color: var(--error); }

        .mon-kpi-card.accent-warn   .mon-kpi-value { color: var(--warning); }

        .mon-kpi-card.accent-ok     .mon-kpi-value { color: var(--success); }

        .mon-kpi-card.accent-primary .mon-kpi-value { color: var(--accent); }


        /* Grid principal: mapa + feed */
        .mon-board {
            display: grid;
            grid-template-columns: 1fr 360px;
            gap: 12px;
        }


        .mon-panel {
            background: var(--bg-card); border: 1px solid var(--border);
            border-radius: var(--r-lg);
            display: flex; flex-direction: column;
            overflow: hidden;
        }

        .mon-panel-head {
            padding: 12px 14px; border-bottom: 1px solid var(--border);
            display: flex; justify-content: space-between; align-items: center; gap: 8px;
        }

        .mon-panel-title {
            font-size: 12px; font-weight: 800; color: var(--text-title);
            text-transform: uppercase; letter-spacing: 0.6px;
            display: flex; align-items: center; gap: 6px;
        }

        .mon-panel-meta { font-size: 11px; color: var(--text-muted); }


        #mon-map { width: 100%; height: 520px; }


        /* Feed */
        .mon-feed { padding: 8px; overflow-y: auto; max-height: 520px; display: flex; flex-direction: column; gap: 6px; }

        .mon-feed-empty { text-align: center; padding: 36px 12px; color: var(--text-muted); font-size: 12px; }

        .mon-feed-item {
            padding: 10px 12px; border-radius: var(--r-md);
            background: var(--bg-input); border: 1px solid var(--border);
            display: flex; gap: 10px; align-items: flex-start;
            transition: var(--t);
        }

        .mon-feed-item:hover { border-color: rgba(89,107,255,0.30); }

        .mon-feed-dot {
            width: 8px; height: 8px; border-radius: 50%;
            flex-shrink: 0; margin-top: 5px;
        }

        .mon-feed-body { flex: 1; min-width: 0; }

        .mon-feed-title { font-size: 12px; font-weight: 700; color: var(--text-title); margin-bottom: 2px; }

        .mon-feed-meta { font-size: 10px; color: var(--text-muted); }


        /* Stub section */
        .mon-stub {
            background: var(--bg-card); border: 1px dashed var(--border);
            border-radius: var(--r-lg); padding: 40px 24px;
            display: flex; flex-direction: column; gap: 8px; align-items: center;
            color: var(--text-muted); text-align: center;
        }

        .mon-stub h3 { color: var(--text-title); margin: 4px 0; font-size: 16px; }

        .mon-stub p { font-size: 12px; max-width: 460px; line-height: 1.5; margin: 0; }

        .mon-stub-cta {
            margin-top: 8px; padding: 9px 18px;
            background: var(--accent); border: none; border-radius: var(--r-md);
            color: #fff; font-size: 12px; font-weight: 700; cursor: pointer;
            display: inline-flex; align-items: center; gap: 6px;
            font-family: inherit;
        }

        .mon-stub-cta:hover { background: var(--primary-dark); }


        /* ── Rede de Coordenação (V3 split) ───────────────────────── */
        .rede-layout { display:grid; grid-template-columns: 320px 1fr; gap:16px; align-items:start; }

        .rede-side { display:flex; flex-direction:column; gap:14px; position:sticky; top:22px; }

        .rede-kpi-warn {
            background: linear-gradient(180deg, rgba(228,0,20,0.06) 0%, var(--bg-card) 70%);
            border: 1px solid rgba(228,0,20,0.22);
            border-radius: var(--r-xl); padding: 18px;
        }

        .rede-kpi-warn h4 { margin:0 0 6px 0; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color: var(--text-muted); display:flex; align-items:center; gap:6px; }

        .rede-kpi-warn .val { font-size:30px; font-weight:900; letter-spacing:-.02em; color: var(--error); line-height:1.05; }

        .rede-kpi-warn .sub { font-size:11px; color: var(--text-muted); margin-top:6px; }

        .rede-kpi-grid { display:grid; grid-template-columns: 1fr 1fr; gap:10px; }

        .rede-kpi-mini { background: var(--bg-card); border:1px solid var(--border); border-radius: var(--r-xl); padding:14px; }

        .rede-kpi-mini h4 { margin:0 0 6px 0; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color: var(--text-muted); }

        .rede-kpi-mini .val { font-size:22px; font-weight:900; letter-spacing:-.02em; color: var(--text-title); line-height:1.05; }

        .rede-kpi-mini .val.warning { color: var(--warning); }

        .rede-kpi-mini .sub { font-size:11px; color: var(--text-muted); margin-top:4px; }

        .rede-panel { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r-xl); overflow:hidden; }

        .rede-panel-head { padding:13px 16px; border-bottom: 1px solid var(--border); display:flex; align-items:center; gap:8px; font-size:12px; font-weight:800; color: var(--text-title); letter-spacing:-.01em; }

        .rede-panel-head > i, .rede-panel-head > svg { color: var(--accent); width:14px; height:14px; flex-shrink:0; }

        .rede-panel-body { padding:6px; display:flex; flex-direction:column; }

        .rede-mini-row { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius: var(--r-md); font-size:12px; cursor:pointer; transition: var(--t); }

        .rede-mini-row:hover { background: var(--bg-card-hover); }

        .rede-mini-row .name { flex:1; min-width:0; font-weight:700; color: var(--text-title); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

        .rede-mini-row .pct { font-size:11px; font-weight:800; color: var(--text-secondary); }

        .rede-mini-row .bar { flex:0 0 70px; height:5px; border-radius:99px; background: var(--bg-elevated); overflow:hidden; }

        .rede-mini-row .bar > div { height:100%; border-radius:99px; background: var(--accent); }

        .rede-mini-row .bar.ok > div { background: var(--success); }

        .rede-mini-row .bar.warn > div { background: var(--warning); }

        .rede-mini-row .bar.err > div { background: var(--error); }


        .rede-content { display:flex; flex-direction:column; gap:14px; min-width:0; }

        .rede-toolbar { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

        .rede-search-wrap { position:relative; flex:1; max-width: 380px; min-width: 220px; }

        .rede-search-wrap > i, .rede-search-wrap > svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); color: var(--text-muted); width:14px; height:14px; pointer-events:none; z-index:1; }

        .rede-search-wrap input { width:100%; height:38px; padding:0 12px 0 36px; border:1px solid var(--border); background: var(--bg-card); border-radius: var(--r-md); font-family:inherit; font-size:13px; color: var(--text-title); outline:none; line-height:1; }

        .rede-search-wrap input::placeholder { color: var(--text-muted); }

        .rede-search-wrap input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(68,76,231,.10); }

        .rede-tabs { display:flex; height:38px; background: var(--bg-card); border:1px solid var(--border); border-radius: var(--r-md); padding:3px; gap:2px; align-items:stretch; }

        .rede-tabs button { background:transparent; border:none; font-family:inherit; font-size:12px; font-weight:600; color: var(--text-secondary); padding:0 14px; border-radius:6px; cursor:pointer; display:inline-flex; align-items:center; gap:6px; }

        .rede-tabs button:hover { color: var(--text-title); }

        .rede-tabs button.active { background: var(--accent); color:#fff; }

        .rede-tabs button.active .cnt { opacity:.85; }

        .rede-tabs .cnt { font-size:10px; font-weight:700; opacity:.65; padding:1px 5px; border-radius:99px; background: rgba(0,0,0,.04); }

        .rede-tabs button.active .cnt { background: rgba(255,255,255,.18); }


        /* Container que envolve grid + paginação — respeita largura da página */
        .rede-grid-wrap { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 14px; display: flex; flex-direction: column; gap: 14px; min-width: 0; }

        .rede-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap:12px; align-content:start; min-height: 120px; }


        /* Paginação */
        .rede-pager { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding-top: 10px; border-top: 1px solid var(--border); font-size: 12px; color: var(--text-secondary); }

        .rede-pager-info { font-weight: 600; }

        .rede-pager-info b { color: var(--text-title); font-weight: 800; }

        .rede-pager-ctrl { display: flex; align-items: center; gap: 4px; }

        .rede-pager-ctrl button { background: var(--bg-card); border: 1px solid var(--border); border-radius: 6px; padding: 6px 10px; font-family: inherit; font-size: 12px; font-weight: 600; color: var(--text-secondary); cursor: pointer; min-width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center; transition: var(--t); }

        .rede-pager-ctrl button:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }

        .rede-pager-ctrl button.active { background: var(--accent); border-color: var(--accent); color: #fff; }

        .rede-pager-ctrl button:disabled { opacity: 0.4; cursor: not-allowed; }

        .rede-pager-ctrl .dots { padding: 0 4px; color: var(--text-muted); }

        .rede-pager-page-size { display: inline-flex; align-items: center; gap: 6px; }

        .rede-pager-page-size select { background: var(--bg-card); border: 1px solid var(--border); border-radius: 6px; padding: 5px 8px; font-family: inherit; font-size: 12px; color: var(--text-secondary); cursor: pointer; }

        .rede-sec-divider { padding:6px 4px; margin-top:6px; font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color: var(--text-muted); grid-column:1/-1; display:flex; align-items:center; gap:8px; }

        .rede-sec-divider .line { flex:1; height:1px; background: var(--border); }

        .rede-sec-divider.no-coord { color: var(--error); }


        /* Borda fininha sempre visível. Hover destaca com cor do accent. */
        .rede-card { background: var(--bg-card); border: 1px solid var(--border-hover); border-radius: var(--r-lg); padding:14px; display:flex; flex-direction:column; gap:10px; cursor:pointer; transition: var(--t); font-family:inherit; text-align:left; box-shadow: 0 1px 2px rgba(15,18,38,.04), 0 2px 8px rgba(15,18,38,.06); }

        .rede-card:hover { border-color: var(--accent); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(68,76,231,.14); }

        /* Mesma borda fininha + gradiente vermelho discreto saindo da esquerda.
           Hover destaca a borda com vermelho e intensifica o gradiente. */
        .rede-card.no-coord { background: linear-gradient(90deg, rgba(239,68,68,0.14), transparent 55%), var(--bg-card); border: 1px solid var(--border-hover); border-radius: var(--r-lg); padding:14px; display:flex; flex-direction:column; gap:10px; cursor:pointer; transition: var(--t); font-family:inherit; text-align:left; box-shadow: 0 1px 2px rgba(15,18,38,.04), 0 2px 8px rgba(15,18,38,.06); }

        .rede-card.no-coord:hover { background: linear-gradient(90deg, rgba(239,68,68,0.22), transparent 60%), var(--bg-card); border-color: var(--error); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(220,38,38,.18); }

        .rede-card-head { display:flex; justify-content:space-between; align-items:flex-start; gap:8px; }

        .rede-card-name { font-size:13px; font-weight:800; color: var(--text-title); letter-spacing:-.01em; line-height:1.2; }

        .rede-card-meta { font-size:11px; color: var(--text-muted); margin-top:2px; }

        .rede-pct-pill { font-size:11px; font-weight:800; padding:3px 9px; border-radius:99px; background: var(--bg-elevated); color: var(--text-muted); flex-shrink:0; }

        .rede-pct-pill.ok { background: rgba(22,163,74,.14); color: var(--success); }

        .rede-pct-pill.mid { background: rgba(217,119,6,.14); color: var(--warning); }

        .rede-pct-pill.low { background: rgba(228,0,20,.10); color: var(--error); }

        .rede-tk-row { display:flex; gap:4px; flex-wrap:wrap; }

        .rede-tk { font-size:10px; font-weight:700; padding:2px 7px; border-radius:5px; letter-spacing:-.01em; }

        .rede-tk.lvl0 { background: rgba(89,107,255,.14); color: var(--accent); }

        .rede-tk.lvl1 { background: rgba(167,139,250,.18); color: #8b5cf6; }

        .rede-tk.lvl2 { background: rgba(251,191,36,.18); color: #b45309; }

        .rede-tk.lvl3 { background: rgba(74,222,128,.18); color: #15803d; }

        .rede-tk.zero { background: var(--bg-elevated); color: var(--text-muted); }

        .rede-card-bar { height:5px; border-radius:99px; background: var(--bg-elevated); overflow:hidden; }

        .rede-card-bar > div { height:100%; border-radius:99px; background: var(--accent); }

        .rede-card-bar.ok > div { background: var(--success); }

        .rede-card-bar.warn > div { background: var(--warning); }

        .rede-card-bar.err > div { background: var(--error); }

        .rede-card-goal { display:flex; justify-content:space-between; font-size:10px; color: var(--text-muted); }

        .rede-card-goal b { color: var(--text-secondary); font-weight:700; }

        .rede-card-alert-tag { font-size:10px; color: var(--error); font-weight:700; display:inline-flex; align-items:center; gap:5px; padding-top:4px; border-top:1px dashed rgba(228,0,20,.20); }

        .rede-card-alert-tag > i, .rede-card-alert-tag > svg { width:11px; height:11px; flex-shrink:0; }


        /* Section visibility */
        .mon-section { display: none; }

        .mon-section.active { display: block; animation: monFade 0.25s ease; }

        @keyframes monFade {
            from { opacity: 0; transform: translateY(4px); }
            to   { opacity: 1; transform: translateY(0); }
        }


        /* Loading placeholder */
        .mon-skel {
            background: linear-gradient(90deg, var(--bg-input) 0%, var(--bg-card-hover) 50%, var(--bg-input) 100%);
            background-size: 200% 100%;
            animation: monSkel 1.4s infinite;
            border-radius: 6px;
            min-height: 14px;
        }

        @keyframes monSkel {
            0% { background-position: 200% 0; }
            100% { background-position: -200% 0; }
        }

    