/* ============================================================
   WifiMaxx PGO — Componentes padronizados (camada de marca)
   Portado de Nova_Interface/css/wmx-components.css.
   Depende de tokens.css. Carregado por base.html DEPOIS dos
   components/*.css existentes, então vence por ordem de cascata
   para as classes compartilhadas (.btn, .card, .pgo-navbar, etc.).
   NÃO inclui o reset universal `*{}` do protótipo (base.css já
   reseta; evitar deslocar layouts de páginas ainda não portadas).
   ============================================================ */

body {
    font-family: var(--font-family);
    background:
        radial-gradient(1200px 600px at 85% -10%, rgba(var(--wmx-magenta-rgb), 0.10), transparent 60%),
        radial-gradient(1000px 500px at 0% 110%, rgba(var(--wmx-orange-rgb), 0.07), transparent 55%),
        linear-gradient(160deg, var(--bg-body-start) 0%, var(--bg-body-end) 100%);
    background-attachment: fixed;
    min-height: 100vh;
    color: var(--text-primary);
    font-size: var(--text-base);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-light); }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-scrollbar-track); }
::-webkit-scrollbar-thumb { background: var(--bg-scrollbar-thumb); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb:hover { background: var(--bg-scrollbar-thumb-hover); }

/* utilhelpers */
.wmx-grad-text {
    background: var(--wmx-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* ============================================================
   NAVBAR — limpa, fundo de superfície + linha de marca embaixo
   Hambúrguer à esquerda · título central · marca à direita
   ============================================================ */
.pgo-navbar {
    position: sticky;
    top: 0;
    z-index: var(--z-navbar);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: var(--navbar-height);
    padding: var(--space-sm) var(--space-2xl);
    background: linear-gradient(180deg, var(--bg-surface), var(--bg-elevated));
    border-bottom: 1px solid var(--border-medium);
    box-shadow: var(--shadow-sm);
}
@supports (backdrop-filter: blur(12px)) {
    .pgo-navbar { backdrop-filter: saturate(140%) blur(14px); background: linear-gradient(180deg, rgba(26,21,36,0.82), rgba(18,14,26,0.82)); }
    [data-theme="light"] .pgo-navbar { background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(250,248,252,0.82)); }
}
/* fina linha de marca sob a navbar */
.pgo-navbar::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 2px;
    background: var(--wmx-gradient);
    opacity: 0.9;
}

.pgo-hamburger {
    position: absolute;
    left: var(--space-xl);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-width: var(--touch-min);
    min-height: var(--touch-min);
    background: var(--bg-hover-light);
    border: 1px solid var(--border-medium);
    border-radius: var(--radius-md);
    cursor: pointer;
    z-index: var(--z-navbar-btn);
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.pgo-hamburger:hover { border-color: var(--border-strong-hover); background: var(--bg-primary-subtle); }
.pgo-hamburger .bar { display: block; width: 20px; height: 2px; background: var(--text-primary); border-radius: 2px; transition: transform var(--transition-base), opacity var(--transition-base); }
.pgo-hamburger.active .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.pgo-hamburger.active .bar:nth-child(2) { opacity: 0; }
.pgo-hamburger.active .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.pgo-navbar-title {
    margin: 0;
    max-width: min(54vw, 520px);
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    text-align: center;
    letter-spacing: -0.01em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pgo-navbar-title i { color: var(--color-primary); margin-right: var(--space-sm); }

/* marca à direita — wordmark gradiente + anel */
.pgo-brand {
    position: absolute;
    right: var(--space-2xl);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-weight: var(--font-bold);
    font-size: var(--text-2xl);
    letter-spacing: -0.02em;
}
.pgo-brand .pgo-brand-mark {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--wmx-gradient);
    -webkit-mask: radial-gradient(circle at 50% 50%, transparent 38%, #000 40%);
    mask: radial-gradient(circle at 50% 50%, transparent 38%, #000 40%);
    transform: rotate(-18deg);
    flex-shrink: 0;
}
.pgo-brand .pgo-brand-text { background: var(--wmx-gradient); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }

.pgo-navbar-actions { position: absolute; right: var(--space-2xl); top: 50%; transform: translateY(-50%); display: flex; align-items: center; gap: var(--space-md); }
.pgo-navbar-actions .pgo-brand { position: static; transform: none; }

/* logo real da empresa na navbar — troca por tema */
.pgo-navbar-logo { display: flex; align-items: center; }
.pgo-navbar-logo img { height: 38px; width: auto; display: block; }
.pgo-navbar-logo .pgo-logo--light { display: none; }
[data-theme="light"] .pgo-navbar-logo .pgo-logo--dark { display: none; }
[data-theme="light"] .pgo-navbar-logo .pgo-logo--light { display: block; }
/* compat: header oficial usa .pgo-navbar-logo--right ancorado à direita */
.pgo-navbar-logo--right { position: absolute; right: var(--space-2xl); top: 50%; transform: translateY(-50%); }
@media (max-width: 768px) { .pgo-navbar-logo img { height: 30px; } .pgo-navbar-actions, .pgo-navbar-logo--right { right: var(--space-lg); } }
.pgo-sidebar__brand img { height: 34px; width: auto; display: block; }
.pgo-sidebar__brand .pgo-logo--light { display: none; }
[data-theme="light"] .pgo-sidebar__brand .pgo-logo--dark { display: none; }
[data-theme="light"] .pgo-sidebar__brand .pgo-logo--light { display: block; }

/* ============================================================
   SIDEBAR
   ============================================================ */
.pgo-sidebar {
    position: fixed;
    top: 0;
    left: calc(-1 * var(--sidebar-width));
    width: var(--sidebar-width);
    height: 100vh;
    background: linear-gradient(180deg, var(--bg-surface), var(--bg-elevated));
    border-right: 1px solid var(--border-medium);
    box-shadow: var(--shadow-lg);
    z-index: var(--z-sidebar);
    padding-top: calc(var(--navbar-height) + var(--space-md));
    overflow-y: auto;
    transition: left var(--transition-base);
}
@supports (backdrop-filter: blur(20px)) { .pgo-sidebar { backdrop-filter: blur(20px); } }
.pgo-sidebar.open { left: 0; }
.pgo-sidebar__brand { display: flex; align-items: center; gap: var(--space-sm); padding: 0 var(--space-2xl) var(--space-md); font-weight: var(--font-bold); font-size: var(--text-2xl); }
.pgo-sidebar-section { padding: var(--space-md) var(--space-2xl) var(--space-2xs); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--ls-pill); color: var(--text-sidebar-section); font-weight: var(--font-semibold); }
.pgo-sidebar-link { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-md) var(--space-2xl); color: var(--text-secondary); font-size: var(--text-md); font-weight: var(--font-medium); border-left: 3px solid transparent; transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast); }
.pgo-sidebar-link i { font-size: var(--text-lg); width: 22px; text-align: center; flex-shrink: 0; }
.pgo-sidebar-link:hover { background: var(--bg-hover-light); color: var(--text-primary); }
.pgo-sidebar-link.active { color: var(--color-primary); border-left-color: var(--color-primary); background: var(--bg-primary-subtle); font-weight: var(--font-semibold); }
.pgo-sidebar-divider { height: 1px; background: var(--border-faint); margin: var(--space-sm) var(--space-2xl); }
.pgo-sidebar-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: var(--z-sidebar-overlay); opacity: 0; visibility: hidden; transition: opacity var(--transition-base), visibility var(--transition-base); }
.pgo-sidebar-overlay.open { opacity: 1; visibility: visible; }

/* ============================================================
   CONTAINER — respiro generoso abaixo da navbar
   ============================================================ */
.pgo-container { max-width: 1440px; margin: 0 auto; padding: var(--space-2xl); }
@media (max-width: 992px) { .pgo-container { padding: var(--space-lg); } }
@media (max-width: 768px) { .pgo-container { padding: var(--space-md); } }

/* ============================================================
   PAGE HEADER
   ============================================================ */
.pgo-page-header { margin-bottom: var(--space-xl); padding-bottom: var(--space-md); border-bottom: 1px solid var(--border-light); display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-lg); flex-wrap: wrap; }
.pgo-page-header__title { display: flex; align-items: center; gap: var(--space-md); margin: 0; color: var(--text-heading); font-size: var(--text-display); font-weight: var(--font-bold); letter-spacing: -0.02em; line-height: 1.1; }
.pgo-page-header__title i { font-size: 0.82em; flex-shrink: 0; background: var(--wmx-gradient); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.pgo-page-header__subtitle { margin: var(--space-2xs) 0 0; color: var(--text-secondary); font-size: var(--text-md); font-weight: var(--font-normal); }
@media (max-width: 768px) { .pgo-page-header__title { font-size: var(--text-3xl); } }

/* ============================================================
   TOOLBAR DE FILTROS — filtros à esquerda · busca + ações à direita
   ============================================================ */
.pgo-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-lg);
    flex-wrap: wrap;
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}
@supports (backdrop-filter: blur(12px)) { .pgo-toolbar { backdrop-filter: blur(var(--glass-blur)); } }
.pgo-toolbar__filters { display: flex; align-items: flex-end; gap: var(--space-md); flex-wrap: wrap; flex: 1 1 auto; min-width: 0; }
.pgo-toolbar__actions { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; }
.pgo-field { display: flex; flex-direction: column; gap: var(--space-2xs); min-width: 0; }
.pgo-field__label { font-size: var(--text-xs); font-weight: var(--font-semibold); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--text-muted); padding-left: 2px; }

/* ============================================================
   CAMPOS DE FORMULÁRIO — um único padrão
   ============================================================ */
.pgo-input, .pgo-select, .form-control, .form-select {
    height: 42px;
    padding: 0 var(--space-md);
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border-medium);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-family: var(--font-family);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}
textarea.form-control, textarea.pgo-input { height: auto; padding: var(--space-sm) var(--space-md); }
.pgo-select, .form-select { appearance: none; -webkit-appearance: none; padding-right: 2.2rem; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%238a8398'%3E%3Cpath d='M4.5 6l3.5 3.5L11.5 6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.8rem center; background-size: 14px; cursor: pointer; }
.pgo-input:focus, .pgo-select:focus, .form-control:focus, .form-select:focus { outline: none; border-color: var(--color-primary); box-shadow: var(--shadow-focus); background: var(--bg-input); }
.pgo-input::placeholder, .form-control::placeholder { color: var(--text-muted); }
.form-label, .pgo-label { font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--text-secondary); margin-bottom: var(--space-2xs); display: inline-block; }

/* ============================================================
   BUSCA — campo único com ícone
   ============================================================ */
.pgo-search { position: relative; display: flex; align-items: center; min-width: 240px; }
.pgo-search i.pgo-search__icon { position: absolute; left: var(--space-md); color: var(--text-muted); font-size: var(--text-md); pointer-events: none; }
.pgo-search input { width: 100%; height: 42px; padding: 0 var(--space-md) 0 2.4rem; background: var(--bg-input); color: var(--text-primary); border: 1px solid var(--border-medium); border-radius: var(--radius-full); font-size: var(--text-base); transition: border-color var(--transition-fast), box-shadow var(--transition-fast); }
.pgo-search input::placeholder { color: var(--text-muted); }
.pgo-search input:focus { outline: none; border-color: var(--color-primary); box-shadow: var(--shadow-focus); }

/* ============================================================
   BOTÕES — uma família única
   ============================================================ */
.btn, .pgo-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-xs);
    height: 42px; padding: 0 var(--space-lg);
    font-family: var(--font-family); font-size: var(--text-base); font-weight: var(--font-semibold);
    border-radius: var(--radius-md); border: 1px solid transparent; cursor: pointer; white-space: nowrap;
    transition: background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), color var(--transition-fast);
}
.btn:active, .pgo-btn:active { transform: translateY(1px); }
.btn-sm { height: 36px; padding: 0 var(--space-md); font-size: var(--text-sm); }
.btn-lg { height: 48px; padding: 0 var(--space-xl); font-size: var(--text-md); }
.btn i { font-size: 0.95em; }

/* primary = superfície de marca (gradiente) */
.btn-primary, .pgo-btn--primary {
    background: var(--wmx-gradient); color: #fff; border: none;
    box-shadow: 0 4px 14px rgba(var(--wmx-magenta-rgb), 0.28);
}
.btn-primary:hover, .pgo-btn--primary:hover { color: #fff; box-shadow: var(--shadow-brand-glow); filter: brightness(1.05); }

.btn-secondary { background: var(--bg-card-alt); color: var(--text-primary); border: 1px solid var(--border-medium); }
.btn-secondary:hover { background: var(--bg-hover-light); border-color: var(--border-strong-hover); }

.btn-success { background: var(--color-success); color: #fff; }
.btn-success:hover { filter: brightness(1.07); color: #fff; }
.btn-danger { background: var(--color-danger); color: #fff; }
.btn-danger:hover { filter: brightness(1.07); color: #fff; }
.btn-warning { background: var(--color-warning); color: #1c1726; }
.btn-warning:hover { filter: brightness(1.05); }

.btn-outline-primary { background: transparent; color: var(--color-primary); border: 1px solid var(--border-strong); }
.btn-outline-primary:hover { background: var(--bg-primary-subtle); border-color: var(--color-primary); color: var(--color-primary-light); }
.btn-outline-secondary, .btn-outline-light { background: transparent; color: var(--text-secondary); border: 1px solid var(--border-medium); }
.btn-outline-secondary:hover, .btn-outline-light:hover { background: var(--bg-hover-light); color: var(--text-primary); border-color: var(--border-strong-hover); }
.btn-outline-success { background: transparent; color: var(--color-success); border: 1px solid rgba(var(--status-online-rgb), 0.4); }
.btn-outline-success:hover { background: var(--color-success-bg); color: var(--color-success); }
.btn-outline-warning { background: transparent; color: var(--color-warning); border: 1px solid rgba(var(--status-atencao-rgb), 0.4); }
.btn-outline-warning:hover { background: var(--color-warning-bg); }
.btn-outline-danger { background: transparent; color: var(--color-danger); border: 1px solid rgba(var(--status-offline-rgb), 0.4); }
.btn-outline-danger:hover { background: var(--color-danger-bg); color: var(--color-danger); }
.btn-outline-info { background: transparent; color: var(--color-info); border: 1px solid rgba(var(--status-inativo-rgb), 0.4); }

.btn-icon { width: 38px; height: 38px; padding: 0; }
.btn:disabled, .btn.disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; box-shadow: none; transform: none; filter: grayscale(30%); }

/* ============================================================
   ABAS — indicador de marca
   ============================================================ */
.nav-tabs, .pgo-tabs { display: flex; gap: var(--space-2xs); border-bottom: 1px solid var(--border-medium); margin-bottom: var(--space-xl); list-style: none; flex-wrap: wrap; }
.nav-tabs .nav-item { list-style: none; }
.nav-tabs .nav-link, .pgo-tab {
    display: inline-flex; align-items: center; gap: var(--space-xs);
    padding: var(--space-sm) var(--space-lg); background: none; border: none;
    color: var(--text-secondary); font-size: var(--text-md); font-weight: var(--font-semibold);
    cursor: pointer; position: relative; border-radius: var(--radius-md) var(--radius-md) 0 0;
    transition: color var(--transition-fast), background var(--transition-fast);
}
.nav-tabs .nav-link:hover, .pgo-tab:hover { color: var(--text-primary); background: var(--bg-hover-light); }
.nav-tabs .nav-link.active, .pgo-tab.active { color: var(--color-primary); }
.nav-tabs .nav-link.active::after, .pgo-tab.active::after {
    content: ""; position: absolute; left: var(--space-md); right: var(--space-md); bottom: -1px; height: 3px;
    background: var(--wmx-gradient); border-radius: 3px 3px 0 0;
}
.pgo-tab-pane { display: none; }
.pgo-tab-pane.active { display: block; animation: wmxFade var(--transition-base); }
@keyframes wmxFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ============================================================
   CARDS
   ============================================================ */
.pgo-card, .card {
    background: linear-gradient(135deg, var(--bg-card-start), var(--bg-card-end));
    border: 1px solid var(--border-medium);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    color: var(--text-primary);
    overflow: hidden;
}
.card-header, .pgo-card__header { padding: var(--space-md) var(--space-lg); border-bottom: 1px solid var(--border-light); font-weight: var(--font-semibold); display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); }
.card-body, .pgo-card__body { padding: var(--space-lg); }
.pgo-section { margin-bottom: var(--space-xl); }
.pgo-section__header { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); margin-bottom: var(--space-md); }
.pgo-section__title { display: flex; align-items: center; gap: var(--space-sm); margin: 0; font-size: var(--text-lg); font-weight: var(--font-bold); color: var(--text-primary); }
.pgo-section__title i { color: var(--color-primary); }

/* ============================================================
   STAT-CARD — KPI compacto clicável (chamados, estoque, etc.)
   ============================================================ */
.stat-card, .stats-card {
    position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: var(--space-2xs);
    padding: var(--space-lg) var(--space-md);
    background: linear-gradient(135deg, var(--bg-card-start), var(--bg-card-end));
    border: 1px solid var(--border-medium);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    height: 100%;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
    overflow: hidden;
}
.stat-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--color-primary); opacity: 0.9; }
.stat-card .stat-icon { font-size: 1.5rem; color: var(--color-primary); margin-bottom: var(--space-2xs); }
.stat-card .stat-value, .stats-card .number { font-size: 1.85rem; font-weight: var(--font-bold); line-height: 1; color: var(--text-heading); letter-spacing: -0.02em; }
.stat-card .stat-label, .stats-card .label { font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--text-secondary); }
.clickable-stat-card { cursor: pointer; }
.clickable-stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong-hover); }

.stat-card.primary::before { background: var(--wmx-gradient); }
.stat-card.primary .stat-icon { color: var(--color-primary); }
.stat-card.info::before { background: var(--color-info); } .stat-card.info .stat-icon { color: var(--color-info); }
.stat-card.warning::before { background: var(--color-warning); } .stat-card.warning .stat-icon { color: var(--color-warning); }
.stat-card.danger::before { background: var(--color-danger); } .stat-card.danger .stat-icon { color: var(--color-danger); }
.stat-card.success::before { background: var(--color-success); } .stat-card.success .stat-icon { color: var(--color-success); }
.stat-card.secondary::before { background: var(--status-manut); } .stat-card.secondary .stat-icon { color: var(--status-manut); }

/* ============================================================
   STATUS-CARD-GLASS — monitoramento (dashboard). 7 variantes.
   ============================================================ */
.status-card-glass {
    position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-xs);
    padding: var(--space-xl) var(--space-md);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(var(--sc-rgb, 224,38,143), 0.30);
    background: linear-gradient(160deg, rgba(var(--sc-rgb, 224,38,143), 0.16), rgba(var(--sc-rgb, 224,38,143), 0.04));
    box-shadow: var(--dash-glass-shadow);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
    overflow: hidden;
}
@supports (backdrop-filter: blur(12px)) { .status-card-glass { backdrop-filter: blur(var(--glass-blur)); } }
.status-card-glass.clickable-card { cursor: pointer; }
.status-card-glass.clickable-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.status-card-glass__icon { width: 54px; height: 54px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-full); background: rgba(var(--sc-rgb, 224,38,143), 0.18); color: rgb(var(--sc-rgb, 224,38,143)); font-size: 1.5rem; margin-bottom: var(--space-2xs); }
.status-card-glass__value { font-size: 2.3rem; font-weight: var(--font-bold); line-height: 1; color: var(--text-heading); letter-spacing: -0.02em; }
.status-card-glass__title { font-size: var(--text-xs); font-weight: var(--font-bold); text-transform: uppercase; letter-spacing: var(--ls-pill); color: var(--text-secondary); }
.status-card-glass__delta { font-size: var(--text-xs); color: var(--text-muted); display: inline-flex; align-items: center; gap: 3px; }
.status-card-glass__delta.up { color: var(--color-success); }
.status-card-glass__delta.down { color: var(--color-danger); }
.glass-card-success { --sc-rgb: var(--status-online-rgb); }
.glass-card-info { --sc-rgb: var(--status-inativo-rgb); }
.glass-card-warning { --sc-rgb: var(--status-atencao-rgb); }
.glass-card-alert { --sc-rgb: var(--status-alerta-rgb); }
.glass-card-danger { --sc-rgb: 231, 76, 60; }
.glass-card-offline { --sc-rgb: 120, 128, 145; }
.glass-card-maintenance { --sc-rgb: 240, 90, 40; }
.glass-card-secondary, .glass-card-divergence { --sc-rgb: var(--status-diverg-rgb); }

/* aliases p/ a marcação real do sistema (status-icon / status-title / status-count) */
.status-card-glass .status-icon { width: 54px; height: 54px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-full); background: rgba(var(--sc-rgb, 224,38,143), 0.18); color: rgb(var(--sc-rgb, 224,38,143)); font-size: 1.5rem; margin-bottom: var(--space-2xs); }
.status-card-glass .status-count { font-size: 2.3rem; font-weight: var(--font-bold); line-height: 1; color: var(--text-heading); letter-spacing: -0.02em; order: 3; }
.status-card-glass .status-title { font-size: var(--text-xs); font-weight: var(--font-bold); text-transform: uppercase; letter-spacing: var(--ls-pill); color: var(--text-secondary); order: 2; }

/* ============================================================
   FORM GRID · PROGRESS · SEGMENTED · SWITCH
   ============================================================ */
.pgo-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-lg); }
.pgo-form-field { display: flex; flex-direction: column; gap: var(--space-2xs); min-width: 0; }
.pgo-form-field .form-label { margin: 0; }
.pgo-form-hint { font-size: var(--text-xs); color: var(--text-muted); }
.pgo-form-field .form-control[readonly], .pgo-input[readonly] { background: var(--bg-input-disabled); color: var(--text-secondary); cursor: default; }

.pgo-progress { height: 8px; border-radius: var(--radius-full); background: var(--bg-hover-light); overflow: hidden; min-width: 90px; }
.pgo-progress__bar { height: 100%; border-radius: var(--radius-full); background: var(--wmx-gradient); }

.pgo-btn-group { display: inline-flex; border: 1px solid var(--border-medium); border-radius: var(--radius-md); overflow: hidden; background: var(--bg-input); }
.pgo-btn-group button { height: 42px; padding: 0 var(--space-lg); border: none; background: transparent; color: var(--text-secondary); font-weight: var(--font-semibold); font-size: var(--text-base); cursor: pointer; transition: background var(--transition-fast), color var(--transition-fast); }
.pgo-btn-group button + button { border-left: 1px solid var(--border-medium); }
.pgo-btn-group button:hover { background: var(--bg-hover-light); color: var(--text-primary); }
.pgo-btn-group button.active { background: var(--wmx-gradient); color: #fff; }

.pgo-switch { display: inline-flex; align-items: center; gap: var(--space-sm); cursor: pointer; user-select: none; font-size: var(--text-sm); color: var(--text-secondary); }
.pgo-switch input { display: none; }
.pgo-switch .pgo-switch__track { width: 40px; height: 22px; border-radius: var(--radius-full); background: var(--bg-switch-off); position: relative; transition: background var(--transition-fast); flex-shrink: 0; }
.pgo-switch .pgo-switch__track::after { content: ""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: #fff; transition: transform var(--transition-fast); }
.pgo-switch input:checked + .pgo-switch__track { background: var(--color-primary); }
.pgo-switch input:checked + .pgo-switch__track::after { transform: translateX(18px); }

/* glass card genérico (watchlist seletor) */
.glass-card { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
@supports (backdrop-filter: blur(12px)) { .glass-card { backdrop-filter: blur(var(--glass-blur)); } }

/* ============================================================
   TABELAS — variante card glass
   ============================================================ */
.pgo-table-card, .table-responsive { border-radius: var(--radius-lg); overflow: auto; -webkit-overflow-scrolling: touch; }
.pgo-table-card { background: linear-gradient(135deg, var(--bg-card-start), var(--bg-card-end)); border: 1px solid var(--border-medium); box-shadow: var(--shadow-sm); }
table.table, table.pgo-table { width: 100%; border-collapse: collapse; color: var(--text-gray-3); font-size: var(--text-base); }
table.table thead th, table.pgo-table thead th {
    position: sticky; top: 0; background: var(--bg-table-head); color: var(--text-secondary);
    font-size: var(--text-xs); font-weight: var(--font-bold); text-transform: uppercase; letter-spacing: var(--ls-label);
    text-align: left; padding: var(--space-md) var(--space-md); border-bottom: 1px solid var(--border-table); white-space: nowrap;
}
table.table tbody td, table.pgo-table tbody td { padding: var(--space-md) var(--space-md); border-bottom: 1px solid var(--border-light); vertical-align: middle; }
table.table tbody tr:hover { background: rgba(var(--wmx-magenta-rgb), 0.06); }
table.table tbody tr:last-child td { border-bottom: none; }

/* ============================================================
   BADGES / PILLS DE STATUS
   ============================================================ */
.badge, .pgo-pill {
    display: inline-flex; align-items: center; gap: var(--space-2xs);
    padding: 0.28em 0.7em; border-radius: var(--radius-full);
    font-size: var(--text-xs); font-weight: var(--font-bold); line-height: 1.3;
    text-transform: uppercase; letter-spacing: var(--ls-label); white-space: nowrap;
}
.pgo-pill--success, .badge.bg-success { background: var(--color-success-bg); color: var(--color-success); border: 1px solid rgba(var(--status-online-rgb), 0.35); }
.pgo-pill--warning, .badge.bg-warning { background: var(--color-warning-bg); color: var(--color-warning); border: 1px solid rgba(var(--status-atencao-rgb), 0.35); }
.pgo-pill--danger, .badge.bg-danger { background: var(--color-danger-bg); color: var(--color-danger); border: 1px solid rgba(var(--status-offline-rgb), 0.35); }
.pgo-pill--info, .badge.bg-info { background: var(--color-info-bg); color: var(--color-info); border: 1px solid rgba(var(--status-inativo-rgb), 0.35); }
.pgo-pill--primary, .badge.bg-primary { background: var(--bg-primary-subtle); color: var(--color-primary-light); border: 1px solid var(--border-strong); }
.pgo-pill--neutral, .badge.bg-secondary { background: var(--bg-hover-light); color: var(--text-secondary); border: 1px solid var(--border-medium); }

/* Legibilidade dos .badge.bg-* (≠ .pgo-pill--*): o utilitário .bg-* do Bootstrap
   pinta o fundo SÓLIDO com !important, então o fundo translúcido das regras acima
   perde — mas a cor de texto (mesma matiz) permanece, ficando texto-sobre-fundo de
   mesma cor (ex.: verde sobre verde sólido, ilegível). Estas regras vêm depois e,
   por ordem de cascata (mesma especificidade 0,2,0), corrigem só a cor do texto
   para contrastar com o fundo sólido do Bootstrap. As pílulas .pgo-pill--* (sem
   !important do Bootstrap) seguem com fundo translúcido + texto colorido intactas. */
.badge.bg-success,
.badge.bg-danger,
.badge.bg-secondary,
.badge.bg-primary  { color: var(--text-inverse); }
.badge.bg-warning,
.badge.bg-info     { color: var(--text-charcoal); }
.badge.text-dark { color: #1c1726; }

/* nível N0-N6 chips */
.pgo-nivel { display: inline-flex; align-items: center; padding: 0.2em 0.6em; border-radius: var(--radius-sm); font-size: var(--text-xs); font-weight: var(--font-bold); background: var(--bg-hover-light); color: var(--text-secondary); border: 1px solid var(--border-medium); }

/* ============================================================
   EMPTY STATE
   ============================================================ */
.pgo-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-sm); padding: var(--space-3xl) var(--space-lg); text-align: center; color: var(--text-empty); }
.pgo-empty i { font-size: 2.6rem; opacity: 0.6; }
.pgo-empty__title { font-size: var(--text-md); font-weight: var(--font-semibold); color: var(--text-secondary); }
.pgo-empty__hint { font-size: var(--text-sm); color: var(--text-muted); }

/* ============================================================
   KANBAN
   ============================================================ */
.pgo-kanban { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(260px, 1fr); gap: var(--space-md); overflow-x: auto; padding-bottom: var(--space-sm); }
.pgo-kanban__col { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-sm); min-height: 200px; }
.pgo-kanban__col-head { display: flex; align-items: center; justify-content: space-between; font-size: var(--text-sm); font-weight: var(--font-bold); text-transform: uppercase; letter-spacing: var(--ls-label); color: var(--text-secondary); padding-bottom: var(--space-sm); border-bottom: 2px solid var(--col-rgb, var(--border-medium)); }
.pgo-kanban__card { background: linear-gradient(135deg, var(--bg-card-start), var(--bg-card-end)); border: 1px solid var(--border-medium); border-radius: var(--radius-md); padding: var(--space-md); box-shadow: var(--shadow-sm); cursor: pointer; transition: transform var(--transition-fast), box-shadow var(--transition-fast); }
.pgo-kanban__card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* ============================================================
   GRID UTILITIES (mín. necessário p/ páginas standalone)
   ============================================================ */
.pgo-grid { display: grid; gap: var(--space-md); }
.pgo-grid--stats { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.pgo-grid--status { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.pgo-grid--2 { grid-template-columns: repeat(2, 1fr); }
.pgo-grid--cards { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
@media (max-width: 768px) { .pgo-grid--2 { grid-template-columns: 1fr; } }

/* collapsible section */
.pgo-collapse__content { transition: max-height var(--transition-base); overflow: hidden; }
.pgo-collapse.collapsed .pgo-collapse__content { max-height: 0 !important; }
.pgo-collapse.collapsed .pgo-collapse__toggle i { transform: rotate(180deg); }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* grid de 7 cards de status (Keep Alive) — usada em dashboard + watchlist */
.wl-status { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--space-md); margin-bottom: var(--space-xl); }
@media (max-width: 1200px) { .wl-status { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px) { .wl-status { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   MODAL leve próprio (.pgo-modal) — NÃO afeta .modal do Bootstrap
   ============================================================ */
.pgo-modal { position: fixed; inset: 0; z-index: var(--z-modal); display: none; align-items: center; justify-content: center; padding: var(--space-lg); }
.pgo-modal.open { display: flex; }
.pgo-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.55); }
@supports (backdrop-filter: blur(4px)) { .pgo-modal__backdrop { backdrop-filter: blur(3px); } }
.pgo-modal__dialog { position: relative; z-index: 1; width: 100%; max-width: 520px; background: linear-gradient(135deg, var(--bg-modal-start), var(--bg-modal-end)); border: 1px solid var(--border-medium); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); overflow: hidden; animation: wmxFade var(--transition-base); }
.pgo-modal__header { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: var(--space-lg); border-bottom: 1px solid var(--border-light); }
.pgo-modal__title { display: flex; align-items: center; gap: var(--space-sm); margin: 0; font-size: var(--text-lg); font-weight: var(--font-bold); }
.pgo-modal__title i { color: var(--color-primary); }
.pgo-modal__body { padding: var(--space-lg); }
.pgo-modal__footer { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-sm); padding: var(--space-lg); border-top: 1px solid var(--border-light); }
.pgo-modal__close { background: none; border: none; color: var(--text-muted); font-size: 1.2rem; cursor: pointer; line-height: 1; }
.pgo-modal__close:hover { color: var(--text-primary); }
