/* ============================================================
   dev.css — Portal do Desenvolvedor / FireGest
   Identidade visual baseada na logo FireGest
   Paleta: navy #091535 · royal #1845c8 · blue #38a8e0 · cyan #5ec8f0
   ============================================================ */

:root {
    /* ── Design system (Claude Design — modo clean, acento Dev azul) ── */
    --accent:       #1F5FD0;
    --accent-2:     #0A2C63;
    --accent-soft:  rgba(31,95,208,.10);
    --accent-glow:  rgba(31,95,208,.40);
    --chip-bg:      rgba(31,95,208,.10);
    --chip-ink:     #1F5FD0;
    --ink:          #121620;
    --muted:        #6B7280;
    --page:         #F4F6F9;
    --panel:        #FFFFFF;
    --panel-2:      #F7F9FB;
    --border:       rgba(15,23,42,.08);
    --shadow:       0 1px 2px rgba(16,24,40,.04), 0 10px 30px rgba(16,24,40,.05);
    --radius:       16px;

    /* ── Shell escuro (sidebar / topbar / login) ───────────── */
    --side-bg:      #0A1A30;
    --topbar-bg:    #0A1A30;
    --side-ink:     rgba(255,255,255,.62);
    --side-active:  rgba(31,95,208,.26);
    --side-border:  rgba(255,255,255,.08);

    /* ── Paleta FireGest (re-apontada p/ o novo tema) ──────── */
    --firegest-primary:   #1F5FD0;
    --firegest-secondary: #0A2C63;
    --firegest-accent:    #1F5FD0;
    --firegest-accent2:   #4F86E0;
    --firegest-bg:        var(--page);
    --firegest-card:      var(--panel);
    --firegest-surface2:  var(--panel-2);
    --firegest-border:    var(--border);
    --firegest-text:      var(--ink);
    --firegest-muted:     var(--muted);
    --firegest-success:   #16A34A;
    --firegest-warning:   #D97706;
    --firegest-danger:    #DC2626;

    /* ── Aliases --dev-* (conteúdo = tema claro) ───────────── */
    --dev-bg:         var(--page);
    --dev-surface:    var(--panel);
    --dev-surface2:   var(--panel-2);
    --dev-border:     var(--border);
    --dev-accent:     var(--accent);
    --dev-accent2:    var(--accent-2);
    --dev-success:    var(--firegest-success);
    --dev-warning:    var(--firegest-warning);
    --dev-danger:     var(--firegest-danger);
    --dev-text:       var(--ink);
    --dev-muted:      var(--muted);
    --dev-sidebar-w:  250px;
    --dev-header-h:   62px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: 'Manrope', system-ui, -apple-system, sans-serif;
    background: var(--page);
    color: var(--ink);
    min-height: 100vh;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* números tabulares (KPIs, valores) */
.num, .dev-stat-value, .dev-table .num { font-family: 'JetBrains Mono', monospace; font-feature-settings: 'tnum'; }

/* ── TELA DE LOGIN ──────────────────────────────────────── */

#dev-login-screen {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(56,168,224,0.10) 0%, transparent 60%),
        radial-gradient(ellipse at 80% 20%, rgba(24,69,200,0.07) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 100%, rgba(94,200,240,0.05) 0%, transparent 50%),
        var(--dev-bg);
    position: relative;
    overflow: hidden;
}

#dev-login-screen::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(56,168,224,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(56,168,224,0.04) 1px, transparent 1px);
    background-size: 60px 60px;
    pointer-events: none;
}

.dev-login-card {
    background: #0E2240;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 26px 40px;
    width: 100%;
    max-width: 420px;
    position: relative;
    box-shadow: 0 25px 60px rgba(0,0,0,0.55), 0 0 0 1px rgba(31,95,208,0.14);
}

.dev-login-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(56,168,224,0.12);
    border: 1px solid rgba(56,168,224,0.28);
    color: var(--firegest-accent2);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 20px;
    margin-bottom: 28px;
}

.dev-login-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--dev-accent);
    animation: blink 2s infinite;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

.dev-login-logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    border-radius: 0;
    padding: 0;
    margin-bottom: 12px;
    box-shadow: none;
    backdrop-filter: none;
}

.dev-login-logo {
    max-width: 180px;
    max-height: 72px;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

@media (max-width: 600px) {
    .dev-login-logo { max-width: 150px; max-height: 60px; }
}
@media (max-width: 380px) {
    .dev-login-logo { max-width: 130px; max-height: 52px; }
}

.dev-login-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 16px;
    letter-spacing: -0.02em;
}

.dev-login-subtitle {
    font-size: 0.82rem;
    color: #CBD5E1;
    margin-bottom: 32px;
}

.dev-field {
    margin-bottom: 11px;
}

.dev-field label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(255,255,255,0.92);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 5px;
}

.dev-field-wrap {
    position: relative;
}

.dev-field-wrap .dev-field-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--dev-muted);
    font-size: 18px;
    pointer-events: none;
}

.dev-input {
    width: 100%;
    background: #0A1A30;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 10px;
    padding: 12px 14px 12px 42px;
    color: #F8FAFC;
    font-size: 0.9rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    outline: none;
}

.dev-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(31,95,208,0.25);
}

.dev-input::placeholder { color: rgba(255,255,255,0.35); }
.dev-input { color: #F8FAFC; }

.dev-2fa-note {
    font-size: 0.72rem;
    color: var(--dev-muted);
    margin-top: 5px;
}

.dev-btn-login {
    width: 100%;
    padding: 13px;
    background: linear-gradient(135deg, var(--firegest-accent), var(--firegest-primary));
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.1s;
    margin-top: 8px;
    box-shadow: 0 4px 20px rgba(56,168,224,0.30);
}

.dev-btn-login:hover { opacity: 0.92; }
.dev-btn-login:active { transform: scale(0.98); }
.dev-btn-login:disabled { opacity: 0.5; cursor: not-allowed; }

/* Spinner do botão durante o login */
.dev-btn-login.is-loading { color: transparent !important; pointer-events: none; position: relative; opacity: 1; }
.dev-btn-login.is-loading::after {
    content: ""; position: absolute; top: 50%; left: 50%; width: 18px; height: 18px;
    margin: -9px 0 0 -9px; border: 2px solid rgba(255,255,255,0.45); border-top-color: #fff;
    border-radius: 50%; animation: btn-spin 0.6s linear infinite;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

.dev-login-links {
    display: flex;
    justify-content: center;
    margin-top: 12px;
}

.dev-login-links a {
    color: var(--dev-accent);
    font-size: 0.8rem;
    text-decoration: none;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.dev-login-links a:hover { opacity: 1; }

.dev-login-warning {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(239,68,68,0.08);
    border: 1px solid rgba(239,68,68,0.2);
    border-radius: 8px;
    padding: 10px 14px;
    margin-top: 24px;
    font-size: 0.75rem;
    color: #fca5a5;
}

.dev-login-warning .material-symbols-outlined {
    font-size: 16px;
    color: var(--dev-danger);
    flex-shrink: 0;
}

.dev-login-error {
    background: rgba(239,68,68,0.12);
    border: 1px solid rgba(239,68,68,0.3);
    color: #fca5a5;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 0.82rem;
    margin-top: 14px;
    display: none;
}

/* ── TÍTULOS — conteúdo escuro (tema claro); login branco (card escuro) ── */

#dev-app h1, #dev-app h2, #dev-app h3, #dev-app h4 {
    color: var(--ink) !important;
}
#dev-login-screen h1, #dev-login-screen h2 {
    color: #FFFFFF !important;
}

/* título da topbar (shell escuro) */
.dev-topbar-title { color: #FFFFFF !important; }

/* ── LAYOUT DO PAINEL ───────────────────────────────────── */

#dev-app { display: none; height: 100vh; }

.dev-layout {
    display: flex;
    height: 100vh;
    overflow: hidden;
}

/* ── SIDEBAR ────────────────────────────────────────────── */

.dev-sidebar {
    width: var(--dev-sidebar-w);
    background: var(--side-bg);
    border-right: 1px solid var(--side-border);
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    overflow-y: auto;
}

.dev-sidebar-brand {
    padding: 18px 20px;
    border-bottom: 1px solid var(--side-border);
    display: flex;
    align-items: center;
    justify-content: center;
}

.dev-sidebar-logo {
    max-width: 140px;
    max-height: 48px;
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
    filter: drop-shadow(0 2px 8px rgba(56,168,224,0.25));
}

@media (max-width: 768px) {
    .dev-sidebar-logo { max-width: 110px; max-height: 38px; }
}

.dev-sidebar-section {
    padding: 16px 12px 6px;
    font-size: 0.62rem;
    font-weight: 700;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.dev-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    margin: 2px 8px;
    border-radius: 11px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--side-ink);
    transition: background 0.15s, color 0.15s, box-shadow 0.15s;
    border: none;
    background: none;
    width: calc(100% - 16px);
    text-align: left;
    font-family: 'Manrope', sans-serif;
}

.dev-nav-item:hover {
    background: rgba(255,255,255,0.06);
    color: #FFFFFF;
}

.dev-nav-item.active {
    background: var(--side-active);
    color: #FFFFFF;
    box-shadow: inset 3px 0 0 var(--accent);
}

.dev-nav-item .material-symbols-outlined {
    font-size: 18px;
    flex-shrink: 0;
}

.dev-nav-badge {
    margin-left: auto;
    background: var(--dev-accent);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 10px;
}

.dev-sidebar-footer {
    margin-top: auto;
    padding: 12px 14px 14px;
    border-top: 1px solid var(--side-border);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
}

/* botão "Sair do sistema" — rodapé da sidebar (acima da versão) */
.dev-sidebar-logout {
    display: flex;
    align-items: center;
    gap: 11px;
    width: 100%;
    padding: 11px 13px;
    border-radius: 11px;
    border: 1px solid var(--side-border);
    background: rgba(255,255,255,0.05);
    color: rgba(255,255,255,0.72);
    font: 600 0.84rem 'Manrope', sans-serif;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.dev-sidebar-logout .material-symbols-outlined { font-size: 19px; flex-shrink: 0; }

.dev-sidebar-logout:hover {
    background: rgba(220,38,38,0.18);
    border-color: rgba(220,38,38,0.40);
    color: #fff;
}

.dev-sidebar-logout:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.dev-sidebar-footer .dev-version-label { text-align: center; }

.dev-version-label {
    font-size: 0.65rem;
    color: var(--side-ink);
    opacity: 0.7;
    letter-spacing: 0.05em;
    user-select: none;
}

/* ── BOTÃO LOGOUT (topbar) ──────────────────────────────── */

.dev-logout-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    border: 1px solid var(--side-border);
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.72);
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
    flex-shrink: 0;
    margin-left: auto;
}

.dev-logout-btn .material-symbols-outlined { font-size: 17px; }

.dev-logout-btn:hover {
    color: var(--firegest-danger);
    border-color: rgba(239,68,68,0.35);
    background: rgba(239,68,68,0.08);
}

.dev-logout-btn:focus-visible {
    outline: 2px solid var(--firegest-accent);
    outline-offset: 2px;
}

.dev-user-info {
    flex: 1;
    min-width: 0;
}

.dev-user-name {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--dev-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dev-user-role {
    font-size: 0.65rem;
    color: var(--dev-accent);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* ── ÁREA PRINCIPAL ─────────────────────────────────────── */

.dev-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.dev-topbar {
    height: var(--dev-header-h);
    background: var(--topbar-bg);
    border-bottom: 1px solid var(--side-border);
    display: flex;
    align-items: center;
    padding: 0 24px;
    gap: 16px;
    flex-shrink: 0;
}

.dev-topbar-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #FFFFFF;
    flex: 1;
}

.dev-topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.dev-btn-icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid var(--dev-border);
    background: var(--dev-surface2);
    color: var(--dev-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}

.dev-btn-icon:hover { color: var(--dev-text); border-color: var(--dev-accent); }
.dev-btn-icon .material-symbols-outlined { font-size: 18px; }

.dev-content {
    flex: 1;
    overflow-y: auto;
    padding: 28px;
}

/* ── CARDS E STATS ──────────────────────────────────────── */

.dev-stats-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-bottom: 28px;
}

@media (max-width: 1200px) {
    .dev-stats-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .dev-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .dev-stats-grid { grid-template-columns: 1fr; }
}

.dev-stat-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 20px 20px 16px;
    position: relative;
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    cursor: default;
}

.dev-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 36px rgba(16,24,40,0.10);
}

.dev-stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--dev-card-accent, linear-gradient(90deg, var(--dev-accent), var(--dev-accent2)));
    border-radius: 14px 14px 0 0;
}

.dev-stat-card::after {
    content: '';
    position: absolute;
    bottom: 0; right: 0;
    width: 80px; height: 80px;
    background: var(--dev-card-glow, rgba(74,222,128,0.04));
    border-radius: 50%;
    transform: translate(20px, 20px);
}

/* variantes de cor — borda superior + glow decorativo (opacity 0.05) */
.dev-stat-card.color-blue   { --dev-card-accent: linear-gradient(90deg,#3B82F6,#60A5FA); --dev-card-glow: rgba(59,130,246,0.05);  border-top: 2px solid #3B82F6; }
.dev-stat-card.color-green  { --dev-card-accent: linear-gradient(90deg,#10B981,#34D399); --dev-card-glow: rgba(16,185,129,0.05);  border-top: 2px solid #10B981; }
.dev-stat-card.color-red    { --dev-card-accent: linear-gradient(90deg,#EF4444,#F87171); --dev-card-glow: rgba(239,68,68,0.05);   border-top: 2px solid #EF4444; }
.dev-stat-card.color-yellow { --dev-card-accent: linear-gradient(90deg,#F59E0B,#FCD34D); --dev-card-glow: rgba(245,158,11,0.05);  border-top: 2px solid #F59E0B; }
.dev-stat-card.color-purple { --dev-card-accent: linear-gradient(90deg,#8B5CF6,#A78BFA); --dev-card-glow: rgba(139,92,246,0.05);  border-top: 2px solid #8B5CF6; }

.dev-stat-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: 10px;
    padding-right: 36px;
}

.dev-stat-value {
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--ink);
    line-height: 1;
    margin-bottom: 5px;
    letter-spacing: -0.5px;
    font-variant-numeric: tabular-nums;
}

.dev-stat-sub {
    font-size: 0.73rem;
    color: var(--muted);
}

.dev-stat-icon {
    position: absolute;
    top: 18px;
    right: 16px;
    font-size: 24px;
    opacity: 0.05;
}

.dev-stat-card.color-blue   .dev-stat-icon { color: #60A5FA; }
.dev-stat-card.color-green  .dev-stat-icon { color: #34D399; }
.dev-stat-card.color-red    .dev-stat-icon { color: #F87171; }
.dev-stat-card.color-yellow .dev-stat-icon { color: #FCD34D; }
.dev-stat-card.color-purple .dev-stat-icon { color: #A78BFA; }

/* ── SEÇÃO TÍTULO DASHBOARD ─────────────────────────────── */

.dev-dash-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    margin-top: 4px;
}

.dev-dash-section h3 {
    font-size: 0.95rem;
    font-weight: 700;
    color: #FFFFFF;
}

.dev-dash-section-sub {
    font-size: 0.78rem;
    color: #94A3B8;
    margin-top: 2px;
}

/* ── BADGE MRR ──────────────────────────────────────────── */

.dev-mrr-value {
    font-size: 1.55rem;
}

/* ── TABELAS ────────────────────────────────────────────── */

.dev-table-wrap {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.dev-table-header {
    padding: 18px 22px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 12px;
}

.dev-table-header h3 {
    font-size: 0.9rem;
    font-weight: 700;
    color: #FFFFFF;
    flex: 1;
}

.dev-search-input {
    background: var(--dev-surface2);
    border: 1px solid var(--dev-border);
    border-radius: 8px;
    padding: 8px 14px;
    color: var(--dev-text);
    font-size: 0.82rem;
    outline: none;
    width: 220px;
    transition: border-color 0.2s;
}

.dev-search-input:focus { border-color: var(--dev-accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.dev-search-input::placeholder { color: var(--muted); }

.dev-table {
    width: 100%;
    border-collapse: collapse;
}

.dev-table th {
    padding: 11px 22px;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 1px solid var(--border);
    text-align: left;
    background: var(--panel-2);
}

.dev-table td {
    padding: 13px 22px;
    font-size: 0.85rem;
    border-bottom: 1px solid var(--border);
    color: var(--ink);
}

.dev-table tr:last-child td { border-bottom: none; }
.dev-table tr:hover td { background: var(--panel-2); }

/* ── BADGES ─────────────────────────────────────────────── */

.dev-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 9px;
    border-radius: 12px;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.03em;
}

.dev-badge-success { background: rgba(22,163,74,0.12);  color: #15803D; }
.dev-badge-warning { background: rgba(217,119,6,0.14);  color: #B45309; }
.dev-badge-danger  { background: rgba(220,38,38,0.12);  color: #B91C1C; }
.dev-badge-info    { background: var(--chip-bg);        color: var(--chip-ink); }
.dev-badge-muted   { background: rgba(100,116,139,0.12); color: #475569; }

/* ── BOTÕES DE AÇÃO ─────────────────────────────────────── */

.dev-action-btn {
    padding: 5px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid transparent;
    transition: opacity 0.15s;
    margin-right: 4px;
}

.dev-action-btn:hover { opacity: 0.8; }

.dev-action-btn-primary {
    background: #2563EB;
    border-color: #2563EB;
    color: #FFFFFF;
}

.dev-action-btn-primary:hover {
    background: #3B82F6;
    border-color: #3B82F6;
    opacity: 1;
}

.dev-action-btn-danger {
    background: rgba(239,68,68,0.12);
    border-color: rgba(239,68,68,0.25);
    color: #f87171;
}

.dev-action-btn-success {
    background: rgba(16,185,129,0.12);
    border-color: rgba(16,185,129,0.25);
    color: #34d399;
}

.dev-action-btn-edit {
    background: rgba(59,130,246,0.15);
    border-color: rgba(59,130,246,0.35);
    color: #60A5FA;
}
.dev-action-btn-edit:hover {
    background: rgba(59,130,246,0.25);
    border-color: rgba(59,130,246,0.55);
    opacity: 1;
}

.dev-action-btn-open {
    background: rgba(16,185,129,0.15);
    border-color: rgba(16,185,129,0.35);
    color: #34D399;
}
.dev-action-btn-open:hover {
    background: rgba(16,185,129,0.25);
    border-color: rgba(16,185,129,0.55);
    opacity: 1;
}
.dev-action-btn-open:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ── Visualizar Empresa ────────────────────────────────────── */
.dev-ver-header {
    display: flex;
    align-items: center;
    gap: 20px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 20px 24px;
}

.dev-ver-logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
    border-radius: 10px;
    background: rgba(255,255,255,0.06);
    padding: 8px;
    flex-shrink: 0;
    border: 1px solid rgba(255,255,255,0.1);
}

.dev-ver-logo-placeholder {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    flex-shrink: 0;
    color: var(--dev-muted);
    font-size: 32px;
}

.dev-ver-nome {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dev-text);
    line-height: 1.2;
}

.dev-ver-fantasia {
    font-size: 0.85rem;
    color: var(--dev-muted);
    margin-top: 3px;
}

/* caixas de preview de imagem na tela de visualização */
.dev-ver-img-box {
    width: 180px;
    height: 120px;
    border-radius: 10px;
    background: repeating-conic-gradient(rgba(255,255,255,0.04) 0% 25%, transparent 0% 50%) 0 0 / 16px 16px;
    border: 1px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 10px;
}

.dev-ver-img-box img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 4px;
}

/* favicon: caixa menor, proporção quadrada */
.dev-ver-img-box--favicon {
    width: 96px;
    height: 96px;
    padding: 6px;
}

/* ════════════════════════════════════════════════════════════
   EDITAR EMPRESA — Slide-over panel
════════════════════════════════════════════════════════════ */

/* Backdrop */
.dev-edit-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2,8,18,0.72);
    backdrop-filter: blur(4px);
    z-index: 1300;
    opacity: 0;
    transition: opacity 0.25s;
}
.dev-edit-backdrop.open { opacity: 1; }

/* Panel */
.dev-edit-panel {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(700px, 100vw);
    background: #102544;
    border-left: 1px solid rgba(255,255,255,0.08);
    box-shadow: -10px 0 50px rgba(0,0,0,0.40);
    z-index: 1310;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.28s cubic-bezier(.4,0,.2,1);
    overflow: hidden;
}
.dev-edit-panel.open { transform: translateX(0); }

/* Header */
.dev-edit-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 22px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    flex-shrink: 0;
    background: rgba(255,255,255,0.02);
}
.dev-edit-header-info {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.dev-edit-header-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: rgba(59,130,246,0.15);
    border: 1px solid rgba(59,130,246,0.25);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.dev-edit-header-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #FFFFFF;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 360px;
}
.dev-edit-header-sub {
    font-size: 0.72rem;
    color: #64748B;
    margin-top: 2px;
}
.dev-edit-close-btn {
    width: 34px; height: 34px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04);
    color: #94A3B8;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
}
.dev-edit-close-btn:hover { background: rgba(255,255,255,0.10); color: #F1F5F9; }
.dev-edit-close-btn .material-symbols-outlined { font-size: 18px; }

/* Body */
.dev-edit-body {
    flex: 1;
    overflow-y: auto;
    padding: 22px 24px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* Section titles */
.dev-edit-section-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #64748B;
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.dev-edit-section-title .material-symbols-outlined {
    font-size: 15px;
    color: #60A5FA;
}

/* Grid */
.dev-edit-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 4px;
}
.dev-edit-col2 { grid-column: 1 / -1; }

/* Field */
.dev-edit-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.dev-edit-field label {
    font-size: 0.73rem;
    font-weight: 600;
    color: #94A3B8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.dev-edit-field label .req { color: #EF4444; margin-left: 2px; }

/* Input / Select */
.dev-edit-input,
.dev-edit-select {
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 9px;
    padding: 9px 12px;
    color: #CBD5E1;
    font-size: 0.83rem;
    font-family: inherit;
    outline: none;
    width: 100%;
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
}
.dev-edit-input:focus,
.dev-edit-select:focus {
    border-color: rgba(59,130,246,0.5);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.10);
}
.dev-edit-input::placeholder { color: #475569; }
.dev-edit-select { cursor: pointer; }
.dev-edit-select option { background: #102544; }

/* Módulos grid */
.dev-edit-mods-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 8px;
    margin-bottom: 4px;
}
.dev-edit-mod-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.78rem;
    color: #94A3B8;
    transition: background 0.14s, border-color 0.14s;
    user-select: none;
}
.dev-edit-mod-item:hover { background: rgba(255,255,255,0.07); color: #CBD5E1; }
.dev-edit-mod-item input[type="checkbox"] {
    accent-color: #3B82F6;
    width: 14px; height: 14px;
    flex-shrink: 0;
    cursor: pointer;
}
.dev-edit-mod-item:has(input:checked) {
    background: rgba(59,130,246,0.12);
    border-color: rgba(59,130,246,0.30);
    color: #93C5FD;
}

/* Footer */
.dev-edit-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 22px;
    border-top: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.02);
    flex-shrink: 0;
    flex-wrap: wrap;
}
.dev-edit-footer-hint {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.71rem;
    color: #475569;
}

/* Footer buttons */
.dev-edit-btn-cancel {
    padding: 8px 18px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.10);
    background: transparent;
    color: #94A3B8;
    font-size: 0.82rem;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}
.dev-edit-btn-cancel:hover { background: rgba(255,255,255,0.07); color: #F1F5F9; }

.dev-edit-btn-save {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 20px;
    border-radius: 8px;
    border: none;
    background: #2563EB;
    color: #FFFFFF;
    font-size: 0.82rem;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.15s, box-shadow 0.15s;
}
.dev-edit-btn-save:hover { background: #3B82F6; box-shadow: 0 2px 12px rgba(37,99,235,0.35); }
.dev-edit-btn-save:disabled { opacity: 0.55; cursor: not-allowed; }
.dev-edit-btn-save .material-symbols-outlined { font-size: 16px; }

/* Responsive */
@media (max-width: 768px) {
    .dev-edit-panel { width: 100vw; }
    .dev-edit-grid  { grid-template-columns: 1fr; }
    .dev-edit-col2  { grid-column: 1; }
    .dev-edit-mods-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 420px) {
    .dev-edit-mods-grid { grid-template-columns: 1fr; }
    .dev-edit-footer    { flex-direction: column; align-items: stretch; }
    .dev-edit-footer > div:last-child { flex-direction: column; }
}

/* ── EMPTY STATE ────────────────────────────────────────── */

.dev-empty {
    text-align: center;
    padding: 48px 20px;
    color: var(--dev-muted);
}

.dev-empty .material-symbols-outlined {
    font-size: 48px;
    display: block;
    margin-bottom: 12px;
    opacity: 0.4;
}

.dev-empty p { font-size: 0.85rem; }

/* ── LOADING ────────────────────────────────────────────── */

.dev-spinner {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(56,168,224,0.20);
    border-top-color: var(--firegest-accent);
    border-radius: 50%;
    animation: spin 0.7s linear infinite;
    display: inline-block;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ── SEÇÃO PLACEHOLDER ──────────────────────────────────── */

.dev-placeholder-section {
    background: var(--dev-surface);
    border: 1px dashed var(--dev-border);
    border-radius: 12px;
    padding: 60px 20px;
    text-align: center;
    color: var(--dev-muted);
}

.dev-placeholder-section .material-symbols-outlined {
    font-size: 40px;
    display: block;
    margin-bottom: 12px;
    opacity: 0.3;
}

.dev-placeholder-section h3 {
    font-size: 1rem;
    margin-bottom: 6px;
    color: #FFFFFF;
    opacity: 1;
}

.dev-placeholder-section p { font-size: 0.82rem; }

/* ── TOAST ──────────────────────────────────────────────── */

.dev-toast-area {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dev-toast {
    background: var(--dev-surface);
    border: 1px solid var(--dev-border);
    border-radius: 10px;
    padding: 12px 16px;
    font-size: 0.82rem;
    color: var(--dev-text);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    min-width: 240px;
    animation: slideIn 0.3s ease;
    display: flex;
    align-items: center;
    gap: 10px;
}

.dev-toast.success { border-left: 3px solid var(--dev-success); }
.dev-toast.error   { border-left: 3px solid var(--dev-danger); }
.dev-toast.info    { border-left: 3px solid var(--dev-accent); }

@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to   { transform: translateX(0); opacity: 1; }
}

/* ── WIZARD / STEPPER ───────────────────────────────────────── */

.dev-wizard-wrap {
    max-width: 900px;
    margin: 0 auto;
}

.dev-stepper {
    display: flex;
    align-items: center;
    margin-bottom: 32px;
    gap: 0;
}

.dev-step-line {
    flex: 1;
    height: 2px;
    background: var(--dev-border);
    transition: background 0.3s;
}
.dev-step-line.done { background: var(--firegest-success); }

.dev-wizard-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 14px;
    padding: 28px 32px 24px;
}

.dev-wizard-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--dev-border);
}

.dev-wizard-title .material-symbols-outlined {
    font-size: 20px;
    color: var(--firegest-accent);
}

/* Form grid — 2 colunas */
.dev-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.dev-col-2 { grid-column: 1 / -1; }

.dev-form-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: rgba(255,255,255,0.92) !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
    display: block;
}

/* Wizard actions bar */
.dev-wizard-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px solid var(--dev-border);
}

/* ── UPLOAD FIELDS ──────────────────────────────────────────── */

.dev-upload-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 16px;
}

.dev-upload-field { display: flex; flex-direction: column; gap: 7px; }

.dev-upload-zone {
    border: 2px dashed var(--dev-border);
    border-radius: 10px;
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    text-align: center;
    min-height: 110px;
    background: var(--dev-surface2);
    color: rgba(255,255,255,0.75);
}

.dev-upload-zone .material-symbols-outlined { font-size: 28px; opacity: 0.65; }
.dev-upload-zone span:not(.material-symbols-outlined) { font-size: 0.82rem; color: rgba(255,255,255,0.82); }
.dev-upload-zone small { font-size: 0.68rem; color: rgba(255,255,255,0.50); opacity: 1; }

.dev-upload-zone:hover,
.dev-upload-zone.drag-over {
    border-color: var(--firegest-accent);
    background: rgba(56,168,224,0.05);
    color: var(--dev-text);
}

.dev-upload-zone.has-file {
    border-color: var(--firegest-success);
    border-style: solid;
}

.dev-upload-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
    transition: min-height 0.2s;
}

.dev-upload-preview img {
    max-width: 100%;
    max-height: 64px;
    object-fit: contain;
    border-radius: 6px;
    border: 1px solid var(--dev-border);
    padding: 4px;
    background: rgba(255,255,255,0.04);
    margin-top: 6px;
}

.dev-upload-error {
    font-size: 0.72rem;
    color: var(--firegest-danger);
    min-height: 18px;
}

@media (max-width: 640px) {
    .dev-form-grid    { grid-template-columns: 1fr; }
    .dev-col-2        { grid-column: 1; }
    .dev-upload-row   { grid-template-columns: 1fr; }
    .dev-wizard-card  { padding: 20px 16px 18px; }
}

.dev-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    position: relative;
    gap: 8px;
}

.dev-step:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 17px;
    left: 50%;
    width: 100%;
    height: 2px;
    background: var(--dev-border);
    z-index: 0;
    transition: background 0.3s;
}

.dev-step.done:not(:last-child)::after { background: var(--dev-success); }
.dev-step.active:not(:last-child)::after { background: var(--dev-accent); }

.dev-step-circle {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid var(--dev-border);
    background: var(--dev-surface);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--dev-muted);
    position: relative;
    z-index: 1;
    transition: all 0.3s;
    flex-shrink: 0;
}

.dev-step.active .dev-step-circle {
    border-color: var(--firegest-accent);
    background: var(--firegest-accent);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(56,168,224,0.22);
}

.dev-step.done .dev-step-circle {
    border-color: var(--dev-success);
    background: var(--dev-success);
    color: #fff;
}

.dev-step-label {
    font-size: 0.62rem;
    font-weight: 600;
    color: var(--dev-muted);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    transition: color 0.3s;
}

.dev-step.active .dev-step-label { color: #FFFFFF; }
.dev-step.done .dev-step-label   { color: #34D399; }

.dev-wizard-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 14px;
    overflow: hidden;
}

.dev-wizard-header {
    padding: 22px 28px 16px;
    border-bottom: 1px solid var(--dev-border);
    background: rgba(255,255,255,0.02);
}

.dev-wizard-header h2 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; color: #FFFFFF; }
.dev-wizard-header p  { font-size: 0.8rem; color: #CBD5E1; }

.dev-wizard-body   { padding: 28px; }

.dev-wizard-footer {
    padding: 16px 28px;
    border-top: 1px solid var(--dev-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(255,255,255,0.01);
}

/* Form fields */
.dev-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.dev-form-grid .full { grid-column: 1 / -1; }

.dev-form-field { display: flex; flex-direction: column; gap: 7px; }

.dev-form-field label {
    font-size: 0.72rem;
    font-weight: 600;
    color: rgba(255,255,255,0.92) !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.dev-form-field label .req { color: var(--dev-danger); margin-left: 2px; }

.dev-form-input,
.dev-form-select {
    background: var(--dev-surface2);
    border: 1px solid var(--dev-border);
    border-radius: 8px;
    padding: 10px 13px;
    color: var(--dev-text);
    font-size: 0.88rem;
    outline: none;
    width: 100%;
    font-family: inherit;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.dev-form-input:focus,
.dev-form-select:focus {
    border-color: var(--dev-accent);
    box-shadow: 0 0 0 3px rgba(56,168,224,0.15);
}

.dev-form-input::placeholder { color: rgba(255,255,255,0.38); opacity: 1; }
.dev-form-select option { background: var(--dev-surface2); }
.dev-form-hint { font-size: 0.7rem; color: #CBD5E1; opacity: 1; }

input[type="color"].dev-form-input { padding: 4px; height: 42px; cursor: pointer; }

/* Modules */
.dev-modules-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 12px; }

.dev-module-card {
    background: var(--dev-surface2);
    border: 2px solid var(--dev-border);
    border-radius: 10px;
    padding: 14px 16px;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 12px;
    user-select: none;
}

.dev-module-card:hover { border-color: rgba(56,168,224,0.45); background: rgba(56,168,224,0.05); }
.dev-module-card.selected { border-color: var(--firegest-accent); background: rgba(56,168,224,0.12); }
.dev-module-card input[type="checkbox"] { display: none; }

.dev-module-icon {
    width: 34px; height: 34px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

.dev-module-icon .material-symbols-outlined { font-size: 18px; }
.dev-module-label { font-size: 0.82rem; font-weight: 600; color: #FFFFFF; }
.dev-module-sub { font-size: 0.68rem; color: #CBD5E1; margin-top: 1px; }

/* Wizard buttons */
.dev-btn-wizard {
    padding: 9px 20px;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.dev-btn-wizard-next {
    background: linear-gradient(135deg, var(--dev-accent), var(--dev-accent2));
    color: #fff;
}

.dev-btn-wizard-back {
    background: var(--dev-surface2);
    border-color: var(--dev-border);
    color: #B8C5D6;
}

.dev-btn-wizard-back:hover { color: #FFFFFF; border-color: #3B82F6; }

.dev-btn-wizard-submit {
    background: var(--dev-success);
    color: #fff;
}

.dev-btn-wizard-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.dev-wizard-progress { font-size: 0.75rem; color: #CBD5E1; }

.dev-btn-salvar-empresa {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 18px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    border-radius: 7px;
    background: #2563EB;
    color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.08);
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
}

.dev-btn-salvar-empresa .material-symbols-outlined {
    font-size: 15px;
    line-height: 1;
}

.dev-btn-salvar-empresa:hover {
    background: #1D4ED8;
    box-shadow: 0 3px 10px rgba(37,99,235,0.40), inset 0 1px 0 rgba(255,255,255,0.08);
    transform: translateY(-1px);
}

.dev-btn-salvar-empresa:active {
    background: #1E40AF;
    transform: translateY(0);
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* Success */
.dev-success-state { text-align: center; padding: 48px 20px; }

.dev-success-icon {
    width: 72px; height: 72px;
    background: rgba(16,185,129,0.12);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    border: 2px solid rgba(16,185,129,0.3);
}

.dev-success-icon .material-symbols-outlined { font-size: 36px; color: var(--dev-success); }
.dev-success-state h2 { font-size: 1.2rem; font-weight: 700; margin-bottom: 8px; color: #FFFFFF; }
.dev-success-state p  { font-size: 0.85rem; color: #CBD5E1; margin-bottom: 24px; }

.dev-success-details {
    background: var(--dev-surface2);
    border: 1px solid var(--dev-border);
    border-radius: 10px;
    padding: 16px 20px;
    text-align: left;
    margin-bottom: 24px;
    display: inline-block;
    min-width: 280px;
}

.dev-success-details .row { font-size: 0.8rem; padding: 5px 0; display: flex; gap: 8px; }
.dev-success-details .k {
    color: #94A3B8;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.04em;
    min-width: 110px;
    flex-shrink: 0;
}

/* ── CREDENCIAIS — CENTRAL INTEGRADA ───────────────────── */

.dev-cred-wrap { padding: 28px 32px; max-width: 1280px; }

.dev-cred-page-header {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 16px; margin-bottom: 22px;
}
.dev-cred-page-title { font-size: 1.25rem; font-weight: 700; color: #FFFFFF; margin-bottom: 4px; }
.dev-cred-page-sub   { font-size: 0.80rem; color: #CBD5E1; }

/* Empresa cells na tabela */
.dev-cred-empresa-nome { font-size: 0.83rem; font-weight: 600; color: #FFFFFF; }
.dev-cred-empresa-cnpj { font-size: 0.68rem; color: #475569; margin-top: 2px; font-family: monospace; }
.dev-cred-mod-count    { font-size: 0.75rem; color: #94A3B8; }

/* Botão Configurar */
.dev-cred-btn-config {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 12px; font-size: 0.73rem; font-weight: 600;
    border-radius: 6px; background: rgba(37,99,235,0.15);
    color: #60A5FA; border: 1px solid rgba(59,130,246,0.25);
    cursor: pointer; transition: all 0.15s; white-space: nowrap;
}
.dev-cred-btn-config .material-symbols-outlined { font-size: 14px; }
.dev-cred-btn-config:hover { background: rgba(37,99,235,0.28); color: #FFFFFF; }

/* Cabeçalho da tela de detalhe */
.dev-cred-detail-header {
    display: flex; align-items: center; gap: 14px;
    margin-bottom: 16px; flex-wrap: wrap;
}
.dev-cred-back-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 6px 14px; font-size: 0.78rem; font-weight: 600;
    border-radius: 7px; background: transparent; color: #94A3B8;
    border: 1px solid rgba(255,255,255,0.10); cursor: pointer;
    transition: all 0.15s;
}
.dev-cred-back-btn .material-symbols-outlined { font-size: 16px; }
.dev-cred-back-btn:hover { color: #FFFFFF; border-color: rgba(255,255,255,0.22); }

.dev-cred-detail-info {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.dev-cred-detail-nome { font-size: 1rem; font-weight: 700; color: #FFFFFF; }

/* Alerta de acesso suspenso */
.dev-cred-alert-box {
    display: flex; align-items: flex-start; gap: 10px;
    background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.22);
    border-radius: 8px; padding: 12px 14px; margin-bottom: 16px;
    color: #F87171;
}
.dev-cred-alert-box .material-symbols-outlined { font-size: 18px; margin-top: 1px; flex-shrink: 0; }
.dev-cred-alert-box strong { font-size: 0.82rem; color: #F87171; display: block; margin-bottom: 2px; }
.dev-cred-alert-box p { font-size: 0.73rem; color: #94A3B8; margin: 0; }

/* Rodapé de tab */
.dev-cred-tab-footer {
    display: flex; align-items: center; justify-content: flex-end; gap: 10px;
    padding: 16px 20px; border-top: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.015);
}

/* Preview do plano */
.dev-cred-plan-preview {
    background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px; overflow: hidden;
}
.dev-cred-plan-preview-header {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px; background: rgba(255,255,255,0.02);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.dev-cred-plan-preview-nome  { font-size: 0.90rem; font-weight: 700; color: #FFFFFF; }
.dev-cred-plan-preview-desc  { font-size: 0.72rem; color: #94A3B8; margin-top: 2px; }
.dev-cred-plan-preview-valor {
    margin-left: auto; font-size: 1.2rem; font-weight: 800; color: #FFFFFF;
    white-space: nowrap;
}
.dev-cred-plan-preview-valor span { font-size: 0.70rem; color: #64748B; margin-left: 2px; }
.dev-cred-plan-preview-recursos {
    display: flex; flex-wrap: wrap; gap: 8px 20px;
    padding: 12px 18px; border-bottom: 1px solid rgba(255,255,255,0.06);
}
.dev-cred-plan-preview-recursos span {
    display: flex; align-items: center; gap: 5px;
    font-size: 0.75rem; color: #CBD5E1;
}
.dev-cred-plan-limits {
    display: flex; gap: 20px; padding: 10px 18px;
    font-size: 0.73rem; color: #64748B; flex-wrap: wrap;
}
.dev-cred-plan-limits strong { color: #FFFFFF; }

/* Lista de módulos por empresa */
.dev-cred-mods-list { display: flex; flex-direction: column; gap: 8px; }
.dev-cred-mod-item {
    display: flex; align-items: center; gap: 12px;
    padding: 11px 14px; border-radius: 9px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.02);
    transition: border-color 0.15s, background 0.15s;
}
.dev-cred-mod-item.enabled {
    border-color: rgba(59,130,246,0.25);
    background: rgba(59,130,246,0.06);
}
.dev-cred-mod-icon {
    width: 34px; height: 34px; border-radius: 8px;
    background: rgba(59,130,246,0.10); border: 1px solid rgba(59,130,246,0.18);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dev-cred-mod-icon .material-symbols-outlined { font-size: 17px; color: #3B82F6; }
.dev-cred-mod-info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.dev-cred-mod-name { font-size: 0.82rem; font-weight: 600; color: #FFFFFF; }
.dev-cred-mod-cat  { font-size: 0.65rem; color: #475569; }
.dev-cred-mod-tag  {
    display: inline-block; font-size: 0.58rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em; padding: 2px 7px; border-radius: 20px; margin-top: 2px;
    background: rgba(16,185,129,0.12); color: #34D399;
}

/* KPIs da aba Financeiro */
.dev-cred-fin-kpis {
    display: grid; grid-template-columns: repeat(4,1fr); gap: 12px;
    margin-bottom: 4px;
}
@media (max-width: 780px) { .dev-cred-fin-kpis { grid-template-columns: repeat(2,1fr); } }
.dev-cred-fin-kpi {
    background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.07);
    border-radius: 9px; padding: 12px 14px;
    display: flex; flex-direction: column; gap: 4px;
}
.dev-cred-fin-kpi .dev-so-label { margin-bottom: 4px; }
.dev-cred-fin-kpi span:last-child { font-size: 0.92rem; font-weight: 700; color: #FFFFFF; }

@media (max-width: 560px) {
    .dev-cred-wrap { padding: 18px 14px; }
    .dev-cred-detail-header { flex-direction: column; align-items: flex-start; }
}

.dev-cred-selector {
    margin-bottom: 20px;
}

.dev-cred-tabs {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--dev-border);
    margin-bottom: 24px;
    padding-bottom: 0;
}

.dev-cred-tab {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 10px 18px;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    color: #B8C5D6;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    border-radius: 6px 6px 0 0;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
    white-space: nowrap;
}

.dev-cred-tab .material-symbols-outlined {
    font-size: 18px;
}

.dev-cred-tab:hover {
    color: #FFFFFF;
    background: rgba(59,130,246,0.08);
}

.dev-cred-tab.active {
    color: #FFFFFF;
    border-bottom-color: #3B82F6;
    background: rgba(59,130,246,0.10);
}

.dev-cred-tab-content {
    padding-top: 4px;
}

@media (max-width: 700px) {
    .dev-cred-tabs { flex-wrap: wrap; gap: 2px; }
    .dev-cred-tab  { padding: 8px 12px; font-size: 0.78rem; }
}

/* ── PÁGINA PLANOS ──────────────────────────────────────── */

.dev-planos-wrap {
    padding: 28px 32px;
    max-width: 1100px;
}

.dev-planos-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 28px;
    gap: 16px;
}

.dev-planos-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 4px;
}

.dev-planos-subtitle {
    font-size: 0.82rem;
    color: #CBD5E1;
}

.dev-btn-novo-plano {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 8px 18px;
    font-size: 0.80rem;
    font-weight: 600;
    border-radius: 8px;
    background: #2563EB;
    color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.10);
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
    box-shadow: 0 1px 4px rgba(37,99,235,0.30);
}

.dev-btn-novo-plano .material-symbols-outlined { font-size: 16px; }

.dev-btn-novo-plano:hover {
    background: #1D4ED8;
    box-shadow: 0 3px 12px rgba(37,99,235,0.40);
    transform: translateY(-1px);
}

/* Grid */
.dev-planos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

@media (max-width: 900px) {
    .dev-planos-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
    .dev-planos-grid { grid-template-columns: 1fr; }
    .dev-planos-wrap { padding: 20px 16px; }
}

/* Card */
.dev-plano-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 22px 20px 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.dev-plano-card:hover {
    border-color: rgba(59,130,246,0.30);
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
}

.dev-plano-card-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 6px;
}

.dev-plano-nome {
    font-size: 0.95rem;
    font-weight: 700;
    color: #FFFFFF;
}

.dev-plano-desc {
    font-size: 0.78rem;
    color: #94A3B8;
    line-height: 1.5;
}

/* Badge */
.dev-plano-badge {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 3px 10px;
    border-radius: 20px;
    white-space: nowrap;
}

.dev-plano-badge-ativo {
    background: rgba(16,185,129,0.18);
    color: #34D399;
}

.dev-plano-badge-inativo {
    background: rgba(239,68,68,0.18);
    color: #F87171;
}

/* Recursos */
.dev-plano-recursos {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}

.dev-plano-recurso {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.78rem;
    color: #CBD5E1;
}

.dev-plano-recurso .material-symbols-outlined {
    font-size: 15px;
    color: #34D399;
    flex-shrink: 0;
}

/* Ações do card */
.dev-plano-actions {
    display: flex;
    gap: 8px;
    margin-top: 4px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.dev-plano-btn-editar,
.dev-plano-btn-toggle {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 14px;
    font-size: 0.73rem;
    font-weight: 600;
    border-radius: 7px;
    cursor: pointer;
    transition: all 0.15s;
}

.dev-plano-btn-editar .material-symbols-outlined,
.dev-plano-btn-toggle .material-symbols-outlined { font-size: 14px; }

.dev-plano-btn-editar {
    background: #2563EB;
    color: #FFFFFF;
    border: 1px solid transparent;
}

.dev-plano-btn-editar:hover {
    background: #1D4ED8;
    box-shadow: 0 2px 8px rgba(37,99,235,0.35);
}

.dev-plano-btn-toggle {
    background: transparent;
    color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.16);
    flex: 1;
    justify-content: center;
}

.dev-plano-btn-toggle:hover {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.28);
}

/* ── FINANCEIRO SAAS ────────────────────────────────────── */

.dev-fin-wrap { padding: 28px 32px; max-width: 1280px; }

/* Header */
.dev-fin-header {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 16px; margin-bottom: 22px;
}
.dev-fin-title    { font-size: 1.25rem; font-weight: 700; color: #FFFFFF; margin-bottom: 4px; }
.dev-fin-subtitle { font-size: 0.80rem; color: #CBD5E1; max-width: 560px; line-height: 1.5; }

.dev-fin-btn-primary {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 8px 18px; font-size: 0.80rem; font-weight: 600;
    border-radius: 8px; background: #2563EB; color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.10); cursor: pointer;
    white-space: nowrap; transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
    box-shadow: 0 1px 4px rgba(37,99,235,0.30);
}
.dev-fin-btn-primary .material-symbols-outlined { font-size: 16px; }
.dev-fin-btn-primary:hover { background: #1D4ED8; box-shadow: 0 3px 12px rgba(37,99,235,0.40); transform: translateY(-1px); }

.dev-fin-btn-secondary {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 16px; font-size: 0.78rem; font-weight: 600;
    border-radius: 8px; background: transparent; color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.14); cursor: pointer;
    transition: background 0.15s;
}
.dev-fin-btn-secondary .material-symbols-outlined { font-size: 15px; }
.dev-fin-btn-secondary:hover { background: rgba(255,255,255,0.05); }

/* Tabs */
.dev-fin-tabs {
    display: flex; gap: 2px; border-bottom: 1px solid rgba(255,255,255,0.07);
    margin-bottom: 24px; overflow-x: auto; padding-bottom: 0;
}
.dev-fin-tab {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 16px; font-size: 0.78rem; font-weight: 600;
    color: #64748B; background: none; border: none;
    border-bottom: 2px solid transparent; margin-bottom: -1px;
    cursor: pointer; white-space: nowrap; border-radius: 6px 6px 0 0;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.dev-fin-tab .material-symbols-outlined { font-size: 16px; }
.dev-fin-tab:hover  { color: #CBD5E1; background: rgba(255,255,255,0.03); }
.dev-fin-tab.active { color: #FFFFFF; border-bottom-color: #3B82F6; background: rgba(59,130,246,0.06); }

/* KPI Cards */
.dev-fin-kpis {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 20px;
}
@media (max-width: 1100px) { .dev-fin-kpis { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 740px)  { .dev-fin-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px)  { .dev-fin-kpis { grid-template-columns: 1fr; } }

.dev-fin-kpi {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 16px 18px 14px;
    display: flex; flex-direction: column; gap: 4px;
    transition: border-color 0.2s, background 0.2s;
    position: relative; overflow: hidden;
}
.dev-fin-kpi:hover { background: #132B4C; border-color: rgba(255,255,255,0.12); }

.dev-fin-kpi-top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 6px;
}
.dev-fin-kpi-icon { font-size: 20px; }
.dev-fin-kpi-badge {
    font-size: 0.58rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.07em; padding: 2px 7px; border-radius: 20px;
}
.dev-fin-kpi-value {
    font-size: 1.55rem; font-weight: 800; color: #FFFFFF;
    line-height: 1; font-variant-numeric: tabular-nums;
}
.dev-fin-kpi-title {
    font-size: 0.68rem; font-weight: 600; color: #FFFFFF;
    text-transform: uppercase; letter-spacing: 0.06em; margin-top: 4px;
}
.dev-fin-kpi-sub { font-size: 0.68rem; color: #64748B; margin-top: 2px; }

/* Charts grid */
.dev-fin-charts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 16px;
}
@media (max-width: 960px)  { .dev-fin-charts-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 580px)  { .dev-fin-charts-grid { grid-template-columns: 1fr; } }

.dev-fin-chart-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 18px 20px;
    margin-bottom: 16px;
}

.dev-fin-chart-header {
    display: flex; align-items: center; gap: 8px; margin-bottom: 16px;
}
.dev-fin-chart-header .material-symbols-outlined { font-size: 17px; color: #3B82F6; }
.dev-fin-chart-header h3 { font-size: 0.83rem; font-weight: 600; color: #FFFFFF; flex: 1; }
.dev-fin-link {
    display: inline-flex; align-items: center; gap: 3px;
    font-size: 0.72rem; color: #3B82F6; background: none; border: none;
    cursor: pointer; transition: color 0.15s;
}
.dev-fin-link:hover { color: #60A5FA; }

.dev-fin-chart-body canvas { max-height: 220px; }

/* Toolbar */
.dev-fin-toolbar {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 14px; flex-wrap: wrap;
}
.dev-fin-select {
    background: #132B4C; border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px; padding: 8px 12px; color: #F8FAFC;
    font-size: 0.78rem; font-family: inherit; outline: none; cursor: pointer;
}
.dev-fin-select:focus { border-color: #3B82F6; }

/* Table */
.dev-fin-table-wrap { overflow-x: auto; }
.dev-fin-table {
    width: 100%; border-collapse: collapse; font-size: 0.78rem;
}
.dev-fin-table th {
    background: #132B4C; color: #FFFFFF; font-size: 0.65rem;
    font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em;
    padding: 11px 14px; text-align: left; white-space: nowrap;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.dev-fin-table td {
    padding: 11px 14px; color: #CBD5E1;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    white-space: nowrap;
}
.dev-fin-table tr:hover td { background: rgba(255,255,255,0.02); }
.dev-fin-empresa-name { font-weight: 600; color: #FFFFFF; }
.dev-fin-plano-tag {
    font-size: 0.68rem; font-weight: 600; padding: 2px 9px;
    border-radius: 20px; background: rgba(59,130,246,0.12); color: #60A5FA;
}
.dev-fin-valor  { font-weight: 700; color: #FFFFFF; font-variant-numeric: tabular-nums; }
.dev-fin-date   { color: #94A3B8; }
.dev-fin-pagto  { color: #94A3B8; }
.dev-fin-situacao { color: #CBD5E1; }
.dev-fin-empty-row { text-align: center; padding: 32px; color: #475569; }

/* Badges de status */
.dev-fin-badge {
    font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em; padding: 3px 9px; border-radius: 20px; white-space: nowrap;
}
.fin-badge-green  { background: rgba(16,185,129,0.18);  color: #34D399; }
.fin-badge-blue   { background: rgba(59,130,246,0.18);  color: #60A5FA; }
.fin-badge-yellow { background: rgba(245,158,11,0.18);  color: #FCD34D; }
.fin-badge-red    { background: rgba(239,68,68,0.18);   color: #F87171; }
.fin-badge-gray   { background: rgba(100,116,139,0.18); color: #94A3B8; }

/* Row actions */
.dev-fin-row-actions { display: flex; gap: 4px; align-items: center; }
.dev-fin-action-btn {
    width: 28px; height: 28px; border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.08); background: transparent;
    color: #94A3B8; cursor: pointer; display: flex; align-items: center;
    justify-content: center; transition: all 0.15s;
}
.dev-fin-action-btn .material-symbols-outlined { font-size: 14px; }
.dev-fin-action-btn:hover { color: #FFFFFF; border-color: rgba(255,255,255,0.20); background: rgba(255,255,255,0.05); }
.dev-fin-action-danger:hover { color: #F87171; border-color: rgba(239,68,68,0.30); background: rgba(239,68,68,0.08); }

/* Mini KPIs (Receitas / Inadimplência) */
.dev-fin-receitas-wrap, .dev-fin-inadim-header { display: flex; flex-direction: column; gap: 16px; }
.dev-fin-receitas-kpis, .dev-fin-inadim-header {
    display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 4px;
}
.dev-fin-mini-kpi {
    display: flex; align-items: center; gap: 12px;
    background: #102544; border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px; padding: 14px 18px; flex: 1; min-width: 160px;
}
.dev-fin-mini-kpi .material-symbols-outlined { font-size: 22px; flex-shrink: 0; }
.dev-fin-mini-val   { font-size: 1.2rem; font-weight: 800; color: #FFFFFF; line-height: 1; }
.dev-fin-mini-label { font-size: 0.68rem; color: #64748B; margin-top: 3px; }

/* Inadimplência actions */
.dev-fin-inadim-actions {
    display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap;
}

/* Relatórios */
.dev-fin-relatorios-grid {
    display: flex; flex-direction: column; gap: 8px;
}
.dev-fin-relatorio-card {
    display: flex; align-items: center; gap: 14px;
    background: #102544; border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px; padding: 14px 18px;
    transition: border-color 0.2s, background 0.2s;
}
.dev-fin-relatorio-card:hover { background: #132B4C; border-color: rgba(255,255,255,0.13); }
.dev-fin-rel-icon { font-size: 20px; color: #3B82F6; flex-shrink: 0; }
.dev-fin-rel-info { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.dev-fin-rel-title { font-size: 0.83rem; font-weight: 600; color: #FFFFFF; }
.dev-fin-rel-desc  { font-size: 0.72rem; color: #64748B; }
.dev-fin-rel-badge {
    font-size: 0.60rem; font-weight: 700; color: #3B82F6;
    background: rgba(59,130,246,0.10); border: 1px solid rgba(59,130,246,0.20);
    padding: 3px 9px; border-radius: 20px; white-space: nowrap;
}
.dev-fin-rel-btn { flex-shrink: 0; }

@media (max-width: 640px) {
    .dev-fin-wrap { padding: 18px 14px; }
    .dev-fin-tabs { gap: 0; }
    .dev-fin-tab  { padding: 8px 10px; font-size: 0.72rem; }
    .dev-fin-relatorio-card { flex-wrap: wrap; }
}

/* ── PÁGINA MÓDULOS ─────────────────────────────────────── */

.dev-mods-wrap {
    padding: 28px 32px;
    max-width: 1200px;
}

.dev-mods-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 22px;
}

.dev-mods-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 4px;
}

.dev-mods-subtitle {
    font-size: 0.80rem;
    color: #CBD5E1;
    max-width: 540px;
    line-height: 1.5;
}

.dev-btn-novo-modulo {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 8px 18px;
    font-size: 0.80rem;
    font-weight: 600;
    border-radius: 8px;
    background: #2563EB;
    color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.10);
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
    box-shadow: 0 1px 4px rgba(37,99,235,0.30);
}

.dev-btn-novo-modulo .material-symbols-outlined { font-size: 16px; }
.dev-btn-novo-modulo:hover { background: #1D4ED8; box-shadow: 0 3px 12px rgba(37,99,235,0.40); transform: translateY(-1px); }

/* Toolbar */
.dev-mods-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.dev-mods-filters {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
    flex: 1;
}

.dev-mods-sep {
    width: 1px;
    height: 18px;
    background: rgba(255,255,255,0.10);
    margin: 0 4px;
    flex-shrink: 0;
}

.dev-mods-filter {
    padding: 5px 13px;
    border-radius: 6px;
    font-size: 0.73rem;
    font-weight: 600;
    border: 1px solid rgba(255,255,255,0.08);
    background: transparent;
    color: #94A3B8;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}

.dev-mods-filter:hover  { background: rgba(255,255,255,0.05); color: #CBD5E1; }
.dev-mods-filter.active { background: rgba(59,130,246,0.15); border-color: rgba(59,130,246,0.35); color: #FFFFFF; }

.dev-mods-categ.active  { background: rgba(59,130,246,0.12); border-color: rgba(59,130,246,0.30); color: #60A5FA; }

/* Search */
.dev-mods-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    padding: 7px 12px;
    min-width: 210px;
    transition: border-color 0.2s;
}

.dev-mods-search-wrap:focus-within { border-color: #3B82F6; }
.dev-mods-search-wrap .material-symbols-outlined { font-size: 16px; color: #64748B; flex-shrink: 0; }

.dev-mods-search {
    background: none;
    border: none;
    outline: none;
    color: #F8FAFC;
    font-size: 0.80rem;
    font-family: inherit;
    width: 100%;
}

.dev-mods-search::placeholder { color: rgba(255,255,255,0.28); }

/* Contador */
.dev-mods-count {
    font-size: 0.70rem;
    color: #64748B;
    margin-bottom: 14px;
    font-weight: 500;
}

/* Grid de cards */
.dev-mods-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

@media (max-width: 1100px) { .dev-mods-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 780px)  { .dev-mods-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .dev-mods-grid { grid-template-columns: 1fr; } .dev-mods-wrap { padding: 18px 14px; } }

/* Card de módulo */
.dev-mod-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 18px 16px 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

.dev-mod-card:hover {
    background: #132B4C;
    border-color: rgba(255,255,255,0.14);
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
}

.dev-mod-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.dev-mod-icon-wrap {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.dev-mod-icon-wrap .material-symbols-outlined { font-size: 18px; }

.dev-mod-info {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.dev-mod-nome {
    font-size: 0.88rem;
    font-weight: 700;
    color: #FFFFFF;
}

.dev-mod-categ-badge {
    font-size: 0.60rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 2px 8px;
    border-radius: 20px;
}

.dev-mod-desc {
    font-size: 0.74rem;
    color: #94A3B8;
    line-height: 1.5;
    flex: 1;
}

.dev-mod-route {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.68rem;
    color: #475569;
}

.dev-mod-route .material-symbols-outlined { font-size: 13px; }
.dev-mod-route code { font-family: 'Fira Code', monospace, monospace; color: #64748B; }

/* Estado vazio */
.dev-mods-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 52px 20px;
    color: #475569;
}

.dev-mods-empty .material-symbols-outlined {
    font-size: 40px;
    display: block;
    margin-bottom: 10px;
    opacity: 0.5;
}

.dev-mods-empty p { font-size: 0.82rem; }

@media (max-width: 640px) {
    .dev-mods-toolbar { flex-direction: column; align-items: stretch; }
    .dev-mods-search-wrap { min-width: unset; }
}

/* ── SLIDE-OVER (Novo/Editar Plano) ─────────────────────── */

.dev-slideover-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(2px);
    z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}

.dev-slideover-backdrop.open {
    opacity: 1;
    pointer-events: all;
}

.dev-slideover {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(620px, 100vw);
    background: #0E2240;
    border-left: 1px solid rgba(255,255,255,0.08);
    z-index: 1001;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
    box-shadow: -8px 0 40px rgba(0,0,0,0.45);
}

.dev-slideover.open {
    transform: translateX(0);
}

.dev-slideover-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

/* Cabeçalho do slide-over */
.dev-so-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px 18px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    flex-shrink: 0;
    background: rgba(255,255,255,0.02);
}

.dev-so-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 3px;
}

.dev-so-subtitle {
    font-size: 0.75rem;
    color: #94A3B8;
}

.dev-so-close {
    width: 30px;
    height: 30px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(255,255,255,0.04);
    color: #94A3B8;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: color 0.15s, background 0.15s;
    margin-top: 2px;
}

.dev-so-close:hover { color: #FFFFFF; background: rgba(255,255,255,0.08); }
.dev-so-close .material-symbols-outlined { font-size: 18px; }

/* Corpo scrollável */
.dev-so-body {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Seções do formulário */
.dev-so-section {
    background: rgba(255,255,255,0.025);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 10px;
    padding: 18px 18px 20px;
    margin-bottom: 10px;
}

.dev-so-section-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 0.78rem;
    font-weight: 700;
    color: #FFFFFF;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 16px;
}

.dev-so-section-title .material-symbols-outlined {
    font-size: 16px;
    color: #3B82F6;
}

/* Grid de campos */
.dev-so-grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.dev-so-grid3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 14px;
}

.dev-so-field { display: flex; flex-direction: column; gap: 5px; }
.dev-so-field.full { grid-column: 1 / -1; }

/* Labels e inputs */
.dev-so-label {
    font-size: 0.70rem;
    font-weight: 600;
    color: rgba(255,255,255,0.90);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.dev-so-label .req { color: #EF4444; margin-left: 2px; }

.dev-so-input {
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 7px;
    padding: 9px 12px;
    color: #F8FAFC;
    font-size: 0.83rem;
    font-family: inherit;
    outline: none;
    width: 100%;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.dev-so-input:focus {
    border-color: #3B82F6;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}

.dev-so-input::placeholder { color: rgba(255,255,255,0.28); }
.dev-so-input-error { border-color: #EF4444 !important; box-shadow: 0 0 0 3px rgba(239,68,68,0.15) !important; }

.dev-so-textarea {
    resize: vertical;
    min-height: 68px;
}

.dev-so-hint {
    font-size: 0.67rem;
    color: #64748B;
    line-height: 1.4;
}

/* Input com prefixo R$ / % */
.dev-so-input-prefix {
    display: flex;
    align-items: center;
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 7px;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.dev-so-input-prefix:focus-within {
    border-color: #3B82F6;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}

.dev-so-input-prefix > span {
    padding: 0 10px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #64748B;
    border-right: 1px solid rgba(255,255,255,0.06);
    white-space: nowrap;
    line-height: 38px;
}

.dev-so-input-prefix .dev-so-input {
    border: none;
    border-radius: 0;
    box-shadow: none !important;
    flex: 1;
}

/* Color picker */
.dev-so-color {
    width: 38px;
    height: 38px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,0.10);
    background: transparent;
    padding: 3px;
    cursor: pointer;
    flex-shrink: 0;
}

/* Icon preview */
.dev-so-icon-preview {
    font-size: 22px;
    color: #3B82F6;
    flex-shrink: 0;
    line-height: 1;
}

/* Switches */
.dev-so-switches {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.dev-switch-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

.dev-switch-row:last-child { border-bottom: none; }

.dev-switch-label {
    font-size: 0.82rem;
    font-weight: 500;
    color: #E2E8F0;
    display: block;
}

.dev-switch-hint {
    font-size: 0.68rem;
    color: #64748B;
    display: block;
    margin-top: 2px;
}

.dev-switch {
    position: relative;
    display: inline-block;
    width: 38px;
    height: 22px;
    flex-shrink: 0;
}

.dev-switch input { opacity: 0; width: 0; height: 0; }

.dev-switch-track {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.12);
    border-radius: 11px;
    cursor: pointer;
    transition: background 0.2s;
}

.dev-switch-track::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    background: #FFFFFF;
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.dev-switch input:checked + .dev-switch-track {
    background: #2563EB;
}

.dev-switch input:checked + .dev-switch-track::after {
    transform: translateX(16px);
}

.dev-so-trial-days {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.05);
}

/* Módulos */
.dev-modulos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 8px;
}

.dev-modulo-check {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 9px 12px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.03);
    color: #94A3B8;
    font-size: 0.75rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
    position: relative;
    user-select: none;
}

.dev-modulo-check .material-symbols-outlined { font-size: 15px; flex-shrink: 0; }

.dev-modulo-check-mark {
    margin-left: auto;
    font-size: 13px !important;
    opacity: 0;
    color: #34D399;
    transition: opacity 0.15s;
}

.dev-modulo-check:hover {
    border-color: rgba(59,130,246,0.35);
    color: #CBD5E1;
    background: rgba(59,130,246,0.06);
}

.dev-modulo-check.checked {
    border-color: rgba(59,130,246,0.40);
    background: rgba(59,130,246,0.10);
    color: #FFFFFF;
}

.dev-modulo-check.checked .dev-modulo-check-mark { opacity: 1; }

/* Rodapé do slide-over */
.dev-so-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 16px 24px;
    border-top: 1px solid rgba(255,255,255,0.07);
    flex-shrink: 0;
    background: rgba(255,255,255,0.02);
}

.dev-so-btn-cancel {
    padding: 8px 20px;
    font-size: 0.80rem;
    font-weight: 600;
    border-radius: 8px;
    background: transparent;
    color: #CBD5E1;
    border: 1px solid rgba(255,255,255,0.12);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.dev-so-btn-cancel:hover { background: rgba(255,255,255,0.05); color: #FFFFFF; }

.dev-so-btn-save {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 22px;
    font-size: 0.80rem;
    font-weight: 600;
    border-radius: 8px;
    background: #2563EB;
    color: #FFFFFF;
    border: 1px solid rgba(255,255,255,0.10);
    cursor: pointer;
    box-shadow: 0 1px 4px rgba(37,99,235,0.35);
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
}

.dev-so-btn-save .material-symbols-outlined { font-size: 15px; }

.dev-so-btn-save:hover {
    background: #1D4ED8;
    box-shadow: 0 3px 12px rgba(37,99,235,0.45);
    transform: translateY(-1px);
}

@media (max-width: 640px) {
    .dev-slideover { width: 100vw; }
    .dev-so-grid2, .dev-so-grid3 { grid-template-columns: 1fr; }
    .dev-so-body { padding: 16px; }
}

/* ══════════════════════════════════════════════════════════
   CONFIGURAÇÕES DO SISTEMA
══════════════════════════════════════════════════════════ */

.dev-cfg-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ── Cabeçalho ───────────────────────────────────────────── */
.dev-cfg-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    margin-bottom: 0;
}

.dev-cfg-header-text h1 {
    font-size: 1.30rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 4px;
}

.dev-cfg-header-text p {
    font-size: 0.83rem;
    color: #94A3B8;
}

.dev-cfg-save-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 20px;
    background: #2563EB;
    color: #FFFFFF;
    border: none;
    border-radius: 9px;
    font-size: 0.83rem;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 2px 10px rgba(37,99,235,0.35);
    transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
    flex-shrink: 0;
    font-family: inherit;
}

.dev-cfg-save-btn .material-symbols-outlined { font-size: 16px; }

.dev-cfg-save-btn:hover {
    background: #1D4ED8;
    box-shadow: 0 4px 16px rgba(37,99,235,0.45);
    transform: translateY(-1px);
}

/* ── Layout corpo ─────────────────────────────────────────── */
.dev-cfg-body {
    display: flex;
    gap: 0;
    align-items: flex-start;
}

/* ── Sidebar interna ─────────────────────────────────────── */
.dev-cfg-sidenav {
    width: 195px;
    flex-shrink: 0;
    padding: 20px 0;
    border-right: 1px solid rgba(255,255,255,0.06);
    display: flex;
    flex-direction: column;
    gap: 2px;
    position: sticky;
    top: 0;
    max-height: calc(100vh - 140px);
    overflow-y: auto;
}

.dev-cfg-sidenav-item {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 9px 14px;
    border-radius: 8px;
    font-size: 0.81rem;
    font-weight: 500;
    color: #94A3B8;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: color 0.15s, background 0.15s;
    white-space: nowrap;
    font-family: inherit;
}

.dev-cfg-sidenav-item .material-symbols-outlined {
    font-size: 16px;
    flex-shrink: 0;
}

.dev-cfg-sidenav-item:hover {
    color: #CBD5E1;
    background: rgba(255,255,255,0.04);
}

.dev-cfg-sidenav-item.active {
    color: #60A5FA;
    background: rgba(37,99,235,0.12);
}

.dev-cfg-sidenav-item.active .material-symbols-outlined { color: #60A5FA; }

/* ── Conteúdo principal ─────────────────────────────────── */
.dev-cfg-main {
    flex: 1;
    padding: 28px 0 28px 32px;
    min-width: 0;
}

.dev-cfg-section { display: none; }
.dev-cfg-section.active { display: block; }

/* ── Cabeçalho de seção ─────────────────────────────────── */
.dev-cfg-section-heading {
    margin-bottom: 22px;
}

.dev-cfg-section-heading h2 {
    font-size: 1.05rem;
    font-weight: 700;
    color: #FFFFFF;
    margin-bottom: 3px;
}

.dev-cfg-section-heading p {
    font-size: 0.81rem;
    color: #94A3B8;
}

/* ── Cards ───────────────────────────────────────────────── */
.dev-cfg-card {
    background: #102544;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 22px 24px;
    margin-bottom: 18px;
}

.dev-cfg-card-title {
    font-size: 0.74rem;
    font-weight: 700;
    color: #CBD5E1;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* ── Grids ───────────────────────────────────────────────── */
.dev-cfg-grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.dev-cfg-grid3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

/* ── Campos de formulário ────────────────────────────────── */
.dev-cfg-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.dev-cfg-field label,
.dev-cfg-field > label {
    font-size: 0.77rem;
    font-weight: 600;
    color: rgba(255,255,255,0.88) !important;
    letter-spacing: 0.01em;
}

.dev-cfg-field label span {
    font-size: 0.69rem;
    font-weight: 400;
    color: #64748B;
    margin-left: 4px;
}

.dev-cfg-input {
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 8px;
    padding: 9px 12px;
    color: #F8FAFC;
    font-size: 0.82rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
    width: 100%;
}

.dev-cfg-input::placeholder { color: rgba(255,255,255,0.28); opacity: 1; }

.dev-cfg-input:focus {
    border-color: rgba(37,99,235,0.55);
    box-shadow: 0 0 0 3px rgba(37,99,235,0.10);
}

.dev-cfg-select {
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 8px;
    padding: 9px 32px 9px 12px;
    color: #F8FAFC;
    font-size: 0.82rem;
    font-family: inherit;
    outline: none;
    cursor: pointer;
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    transition: border-color 0.15s;
}

.dev-cfg-select:focus { border-color: rgba(37,99,235,0.55); }

.dev-cfg-select option { background: #132B4C; }

/* ── Switch rows ─────────────────────────────────────────── */
.dev-cfg-switch-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 13px 0;
    border-bottom: 1px solid rgba(255,255,255,0.045);
}

.dev-cfg-switch-row:last-child { border-bottom: none; padding-bottom: 0; }
.dev-cfg-switch-row:first-child { padding-top: 0; }

.dev-cfg-switch-row-label {
    font-size: 0.83rem;
    font-weight: 500;
    color: #CBD5E1;
    display: block;
    margin-bottom: 2px;
}

.dev-cfg-switch-row-desc {
    font-size: 0.75rem;
    color: #64748B;
    line-height: 1.4;
}

/* ── Toggle switch ───────────────────────────────────────── */
.dev-cfg-switch {
    position: relative;
    width: 38px;
    height: 20px;
    flex-shrink: 0;
    cursor: pointer;
}

.dev-cfg-switch input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.dev-cfg-switch-track {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.10);
    border-radius: 20px;
    transition: background 0.2s;
}

.dev-cfg-switch-track::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    left: 3px;
    top: 3px;
    background: rgba(255,255,255,0.7);
    border-radius: 50%;
    transition: transform 0.2s, background 0.2s;
}

.dev-cfg-switch input:checked + .dev-cfg-switch-track {
    background: #2563EB;
}

.dev-cfg-switch input:checked + .dev-cfg-switch-track::after {
    transform: translateX(18px);
    background: #FFFFFF;
}

/* ── Badge futuro ────────────────────────────────────────── */
.dev-cfg-badge-future {
    display: inline-flex;
    align-items: center;
    padding: 2px 7px;
    background: rgba(245,158,11,0.14);
    color: #F59E0B;
    border-radius: 4px;
    font-size: 0.63rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-left: 7px;
    vertical-align: middle;
}

/* ── Upload zone ─────────────────────────────────────────── */
.dev-cfg-upload {
    border: 1.5px dashed rgba(255,255,255,0.10);
    border-radius: 10px;
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
    background: rgba(255,255,255,0.015);
    text-align: center;
    min-height: 96px;
}

.dev-cfg-upload:hover {
    border-color: rgba(37,99,235,0.45);
    background: rgba(37,99,235,0.04);
}

.dev-cfg-upload .material-symbols-outlined {
    font-size: 26px;
    color: #64748B;
}

.dev-cfg-upload-text {
    font-size: 0.78rem;
    color: #94A3B8;
    font-weight: 500;
}

.dev-cfg-upload-sub {
    font-size: 0.69rem;
    color: #475569;
}

/* ── Tema buttons ────────────────────────────────────────── */
.dev-cfg-tema-btns {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.dev-cfg-tema-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 0.80rem;
    font-weight: 500;
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(255,255,255,0.03);
    color: #94A3B8;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
    font-family: inherit;
}

.dev-cfg-tema-btn .material-symbols-outlined { font-size: 16px; }

.dev-cfg-tema-btn:hover {
    color: #CBD5E1;
    border-color: rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.05);
}

.dev-cfg-tema-btn.active {
    border-color: rgba(37,99,235,0.55);
    background: rgba(37,99,235,0.12);
    color: #60A5FA;
}

/* ── Color picker ────────────────────────────────────────── */
.dev-cfg-color-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.dev-cfg-color-swatch {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.12);
    overflow: hidden;
    flex-shrink: 0;
    cursor: pointer;
    padding: 0;
    display: block;
}

.dev-cfg-color-swatch input[type="color"] {
    width: 200%;
    height: 200%;
    margin: -25%;
    border: none;
    cursor: pointer;
    padding: 0;
    background: none;
}

/* ── Preview de aparência ────────────────────────────────── */
.dev-cfg-preview {
    background: #071426;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px;
    padding: 14px;
    display: flex;
    gap: 10px;
    align-items: flex-start;
    min-height: 110px;
}

.dev-cfg-preview-sidebar {
    width: 52px;
    background: #102544;
    border-radius: 6px;
    padding: 8px 7px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-shrink: 0;
}

.dev-cfg-preview-logo {
    height: 6px;
    border-radius: 3px;
    background: rgba(255,255,255,0.2);
    margin-bottom: 6px;
}

.dev-cfg-preview-bar {
    height: 4px;
    width: 75%;
    border-radius: 2px;
    background: rgba(255,255,255,0.12);
}

.dev-cfg-preview-bar.active {
    width: 100%;
    background: #2563EB;
    transition: background 0.3s;
}

.dev-cfg-preview-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.dev-cfg-preview-topbar {
    height: 18px;
    background: #102544;
    border-radius: 4px;
}

.dev-cfg-preview-cards {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 5px;
}

.dev-cfg-preview-card {
    height: 34px;
    background: #132B4C;
    border-radius: 5px;
}

/* ── Integrations grid ───────────────────────────────────── */
.dev-cfg-integ-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
    gap: 12px;
}

.dev-cfg-integ-card {
    background: #132B4C;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.dev-cfg-integ-card:hover {
    border-color: rgba(37,99,235,0.28);
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

.dev-cfg-integ-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
}

.dev-cfg-integ-icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.dev-cfg-integ-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: #F8FAFC;
}

.dev-cfg-integ-status {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.71rem;
    font-weight: 500;
}

.dev-cfg-integ-status::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #475569;
    flex-shrink: 0;
}

.dev-cfg-integ-status.connected { color: #10B981; }
.dev-cfg-integ-status.connected::before { background: #10B981; }
.dev-cfg-integ-status.disconnected { color: #64748B; }

.dev-cfg-integ-btn {
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 0.73rem;
    font-weight: 600;
    border: 1px solid rgba(255,255,255,0.10);
    background: transparent;
    color: #94A3B8;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
    width: 100%;
    font-family: inherit;
}

.dev-cfg-integ-btn:hover {
    border-color: rgba(37,99,235,0.4);
    color: #60A5FA;
    background: rgba(37,99,235,0.07);
}

/* ── Backup info rows ────────────────────────────────────── */
.dev-cfg-backup-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

.dev-cfg-backup-info:last-child { border-bottom: none; }

.dev-cfg-backup-info-label {
    font-size: 0.80rem;
    color: #94A3B8;
}

.dev-cfg-backup-info-value {
    font-size: 0.80rem;
    font-weight: 600;
    color: #CBD5E1;
}

/* ── Logs table ──────────────────────────────────────────── */
.dev-cfg-logs-filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.dev-cfg-logs-wrap { overflow-x: auto; }

.dev-cfg-logs-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.79rem;
}

.dev-cfg-logs-table th {
    padding: 10px 14px;
    text-align: left;
    color: #64748B;
    font-size: 0.71rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    white-space: nowrap;
    background: #0b1e38;
}

.dev-cfg-logs-table td {
    padding: 10px 14px;
    color: #CBD5E1;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    vertical-align: middle;
}

.dev-cfg-logs-table tr:last-child td { border-bottom: none; }
.dev-cfg-logs-table tr:hover td { background: rgba(255,255,255,0.018); }

/* ── Botões de ação ──────────────────────────────────────── */
.dev-cfg-btn-danger,
.dev-cfg-btn-neutral,
.dev-cfg-btn-success {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: 7px;
    font-size: 0.76rem;
    font-weight: 600;
    cursor: pointer;
    flex-shrink: 0;
    white-space: nowrap;
    font-family: inherit;
    transition: background 0.15s, box-shadow 0.15s;
}

.dev-cfg-btn-danger .material-symbols-outlined,
.dev-cfg-btn-neutral .material-symbols-outlined,
.dev-cfg-btn-success .material-symbols-outlined { font-size: 14px; }

.dev-cfg-btn-danger {
    background: rgba(239,68,68,0.10);
    color: #EF4444;
    border: 1px solid rgba(239,68,68,0.22);
}
.dev-cfg-btn-danger:hover {
    background: rgba(239,68,68,0.18);
    box-shadow: 0 2px 10px rgba(239,68,68,0.18);
}

.dev-cfg-btn-neutral {
    background: rgba(255,255,255,0.05);
    color: #CBD5E1;
    border: 1px solid rgba(255,255,255,0.10);
}
.dev-cfg-btn-neutral:hover { background: rgba(255,255,255,0.09); }

.dev-cfg-btn-success {
    background: rgba(16,185,129,0.10);
    color: #10B981;
    border: 1px solid rgba(16,185,129,0.22);
}
.dev-cfg-btn-success:hover {
    background: rgba(16,185,129,0.18);
    box-shadow: 0 2px 10px rgba(16,185,129,0.15);
}

/* ── Status badges ───────────────────────────────────────── */
.dev-cfg-status-on {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 0.70rem;
    font-weight: 600;
    background: rgba(16,185,129,0.12);
    color: #10B981;
}

.dev-cfg-status-off {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 0.70rem;
    font-weight: 600;
    background: rgba(255,255,255,0.06);
    color: #94A3B8;
}

/* ── Maintenance banner ──────────────────────────────────── */
.dev-cfg-maint-banner {
    background: rgba(245,158,11,0.07);
    border: 1px solid rgba(245,158,11,0.22);
    border-radius: 10px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
    font-size: 0.82rem;
    color: #F59E0B;
    line-height: 1.5;
}

.dev-cfg-maint-banner .material-symbols-outlined {
    font-size: 20px;
    flex-shrink: 0;
}

/* ── Danger zone ─────────────────────────────────────────── */
.dev-cfg-danger-zone {
    background: rgba(239,68,68,0.04);
    border: 1px solid rgba(239,68,68,0.18);
    border-radius: 12px;
    padding: 22px 24px;
    margin-bottom: 18px;
}

.dev-cfg-danger-title {
    font-size: 0.82rem;
    font-weight: 700;
    color: #EF4444;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.dev-cfg-danger-title .material-symbols-outlined { font-size: 17px; }

.dev-cfg-danger-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 13px 0;
    border-bottom: 1px solid rgba(239,68,68,0.09);
}

.dev-cfg-danger-row:last-child { border-bottom: none; padding-bottom: 0; }
.dev-cfg-danger-row:first-child { padding-top: 0; }

.dev-cfg-danger-row-label {
    font-size: 0.83rem;
    font-weight: 500;
    color: #CBD5E1;
    display: block;
    margin-bottom: 2px;
}

.dev-cfg-danger-row-desc {
    font-size: 0.74rem;
    color: #64748B;
    line-height: 1.4;
}

/* ── Toast notifications ─────────────────────────────────── */
.dev-toast-area {
    position: fixed;
    bottom: 24px;
    right: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 9999;
    pointer-events: none;
}

.dev-toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    border-radius: 10px;
    font-size: 0.82rem;
    font-weight: 500;
    color: #FFFFFF;
    box-shadow: 0 4px 20px rgba(0,0,0,0.35);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.25s, transform 0.25s;
    pointer-events: auto;
    max-width: 320px;
}

.dev-toast.show { opacity: 1; transform: translateY(0); }

.dev-toast-success { background: #0f5132; border: 1px solid rgba(16,185,129,0.35); }
.dev-toast-danger  { background: #5c1a1a; border: 1px solid rgba(239,68,68,0.35);  }
.dev-toast-info    { background: #0c2a5c; border: 1px solid rgba(37,99,235,0.35);  }

.dev-toast .material-symbols-outlined { font-size: 17px; flex-shrink: 0; }

/* ── Integrações — infraestrutura banner ────────────────── */
.dev-cfg-infra-banner {
    display: flex;
    align-items: center;
    gap: 16px;
    background: linear-gradient(135deg, rgba(16,185,129,0.10) 0%, rgba(16,185,129,0.04) 100%);
    border: 1px solid rgba(16,185,129,0.25);
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 18px;
}

.dev-cfg-infra-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: rgba(62,207,142,0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.dev-cfg-infra-info { flex: 1; min-width: 0; }

.dev-cfg-infra-title {
    font-size: 0.88rem;
    font-weight: 700;
    color: #FFFFFF;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 3px;
}

.dev-cfg-infra-subtitle {
    font-size: 0.76rem;
    color: #10B981;
    font-weight: 500;
}

.dev-cfg-infra-stats {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.dev-cfg-infra-stat {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.74rem;
    color: #94A3B8;
    font-weight: 500;
}

.dev-cfg-infra-stat-ok {
    color: #10B981 !important;
    font-weight: 700 !important;
}

/* ── Card Supabase destacado ─────────────────────────────── */
.dev-cfg-integ-supabase-card {
    background: linear-gradient(180deg, rgba(16,185,129,0.10) 0%, rgba(16,185,129,0.03) 100%) !important;
    border: 1px solid rgba(16,185,129,0.40) !important;
}

.dev-cfg-integ-supabase-inner {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.dev-cfg-integ-supabase-left {
    flex: 1;
    min-width: 220px;
}

.dev-cfg-integ-supabase-services {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    flex-shrink: 0;
}

.dev-cfg-supa-service {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 8px;
}

.dev-cfg-supa-service .material-symbols-outlined {
    font-size: 18px;
    color: #3ECF8E;
    flex-shrink: 0;
}

.dev-cfg-supa-service-name {
    font-size: 0.76rem;
    font-weight: 600;
    color: #CBD5E1;
}

.dev-cfg-supa-service-status {
    font-size: 0.69rem;
    font-weight: 600;
    margin-top: 2px;
}

.dev-cfg-supa-service-status.ok      { color: #10B981; }
.dev-cfg-supa-service-status.neutral { color: #64748B; }

.dev-cfg-integ-supabase-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    flex-shrink: 0;
    padding-top: 2px;
}

.dev-cfg-integ-btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 20px;
    border-radius: 8px;
    font-size: 0.80rem;
    font-weight: 600;
    background: rgba(16,185,129,0.14);
    color: #10B981;
    border: 1px solid rgba(16,185,129,0.35);
    cursor: pointer;
    transition: background 0.15s, box-shadow 0.15s;
    font-family: inherit;
    white-space: nowrap;
}

.dev-cfg-integ-btn-primary .material-symbols-outlined { font-size: 16px; }

.dev-cfg-integ-btn-primary:hover {
    background: rgba(16,185,129,0.22);
    box-shadow: 0 2px 12px rgba(16,185,129,0.2);
}

/* ── Badge principal ─────────────────────────────────────── */
.dev-cfg-integ-badge-main {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    background: rgba(16,185,129,0.14);
    color: #10B981;
    border: 1px solid rgba(16,185,129,0.25);
    border-radius: 20px;
    font-size: 0.63rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

/* ── Card "não utilizado" ────────────────────────────────── */
.dev-cfg-integ-card-unused {
    opacity: 0.65;
}

.dev-cfg-integ-card-unused:hover { opacity: 0.85; }

.dev-cfg-integ-status-unused {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.71rem;
    font-weight: 500;
    color: #475569;
}

.dev-cfg-integ-status-unused::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #334155;
    flex-shrink: 0;
}

/* ── Modal Supabase ──────────────────────────────────────── */
.dev-cfg-supa-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 1100;
    opacity: 0;
    transition: opacity 0.22s;
}

.dev-cfg-supa-modal-backdrop.open { opacity: 1; }

.dev-cfg-supa-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -48%) scale(0.97);
    width: min(600px, 92vw);
    max-height: 86vh;
    background: #102544;
    border: 1px solid rgba(16,185,129,0.25);
    border-radius: 16px;
    z-index: 1101;
    flex-direction: column;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.22s, transform 0.22s;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.dev-cfg-supa-modal.open {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.dev-cfg-supa-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    flex-shrink: 0;
}

.dev-cfg-supa-modal-close {
    width: 32px;
    height: 32px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,0.10);
    background: transparent;
    color: #94A3B8;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
}

.dev-cfg-supa-modal-close .material-symbols-outlined { font-size: 17px; }
.dev-cfg-supa-modal-close:hover { background: rgba(255,255,255,0.07); color: #FFFFFF; }

.dev-cfg-supa-modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px 24px;
}

.dev-cfg-supa-modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 16px 24px;
    border-top: 1px solid rgba(255,255,255,0.07);
    flex-shrink: 0;
}

/* Status row no topo do modal */
.dev-cfg-supa-status-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    background: rgba(16,185,129,0.07);
    border: 1px solid rgba(16,185,129,0.15);
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 20px;
}

.dev-cfg-supa-status-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.76rem;
    font-weight: 500;
    color: #10B981;
}

.dev-cfg-supa-status-item .material-symbols-outlined { font-size: 15px; }

/* Seção título dentro do modal */
.dev-cfg-supa-section-title {
    font-size: 0.72rem;
    font-weight: 700;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* Info grid do projeto */
.dev-cfg-supa-info-grid {
    margin-bottom: 20px;
}

.dev-cfg-supa-info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 9px 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
}

.dev-cfg-supa-info-row:last-child { border-bottom: none; }

.dev-cfg-supa-info-label {
    font-size: 0.78rem;
    color: #94A3B8;
    flex-shrink: 0;
}

.dev-cfg-supa-info-value {
    font-size: 0.78rem;
    color: #CBD5E1;
    font-weight: 500;
    text-align: right;
}

.dev-cfg-supa-masked {
    color: #475569 !important;
    letter-spacing: 0.05em;
}

/* Lista de serviços no modal */
.dev-cfg-supa-services-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}

.dev-cfg-supa-service-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: rgba(255,255,255,0.025);
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 8px;
}

.dev-cfg-supa-service-badge {
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 0.68rem;
    font-weight: 700;
    flex-shrink: 0;
}

.dev-cfg-supa-service-badge.ok {
    background: rgba(16,185,129,0.12);
    color: #10B981;
}

.dev-cfg-supa-service-badge.neutral {
    background: rgba(255,255,255,0.06);
    color: #64748B;
}

/* ── Responsivo ──────────────────────────────────────────── */
@media (max-width: 960px) {
    .dev-cfg-sidenav { width: 165px; }
    .dev-cfg-grid3 { grid-template-columns: 1fr 1fr; }
    .dev-cfg-integ-grid { grid-template-columns: repeat(auto-fill, minmax(155px, 1fr)); }
    .dev-cfg-infra-stats { display: none; }
    .dev-cfg-integ-supabase-services { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 700px) {
    .dev-cfg-body { flex-direction: column; }
    .dev-cfg-sidenav {
        width: 100%;
        flex-direction: row;
        overflow-x: auto;
        padding: 12px 4px;
        border-right: none;
        border-bottom: 1px solid rgba(255,255,255,0.06);
        position: static;
        max-height: none;
        gap: 4px;
    }
    .dev-cfg-sidenav-item { flex-shrink: 0; }
    .dev-cfg-main { padding: 16px 0 16px 0; }
    .dev-cfg-grid2,
    .dev-cfg-grid3 { grid-template-columns: 1fr; }
    .dev-cfg-integ-grid { grid-template-columns: 1fr 1fr; }
    .dev-cfg-header { flex-direction: column; }
    .dev-cfg-save-btn { width: 100%; justify-content: center; }
}

/* ════════════════════════════════════════════════════════════
   INTEGRATIONS HUB  (.dev-integ-*)
════════════════════════════════════════════════════════════ */

/* ── Tabs ─────────────────────────────────────────────────── */
.dev-integ-tabs {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
    padding: 4px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--dev-border);
    border-radius: 12px;
    margin-bottom: 18px;
}
.dev-integ-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: var(--dev-muted);
    font-size: 0.78rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    font-family: inherit;
    white-space: nowrap;
}
.dev-integ-tab:hover { background: rgba(255,255,255,0.06); color: #CBD5E1; }
.dev-integ-tab.active {
    background: rgba(37,99,235,0.2);
    color: #60A5FA;
}
.dev-integ-tab-count {
    font-size: 0.68rem;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 99px;
    background: rgba(255,255,255,0.08);
    color: #94A3B8;
    min-width: 18px;
    text-align: center;
}
.dev-integ-tab.active .dev-integ-tab-count {
    background: rgba(37,99,235,0.35);
    color: #93C5FD;
}

/* ── Toolbar ──────────────────────────────────────────────── */
.dev-integ-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.dev-integ-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 200px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--dev-border);
    border-radius: 10px;
    padding: 0 12px;
    transition: border-color 0.15s;
}
.dev-integ-search-wrap:focus-within { border-color: rgba(37,99,235,0.5); }
.dev-integ-search-wrap .material-symbols-outlined { color: #475569; font-size: 18px; }
.dev-integ-search {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #CBD5E1;
    font-size: 0.83rem;
    font-family: inherit;
    padding: 9px 0;
}
.dev-integ-search::placeholder { color: #475569; }
.dev-integ-filters {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.dev-integ-filter {
    padding: 7px 10px !important;
    font-size: 0.78rem !important;
    min-width: 140px;
}

/* ── Category sections ────────────────────────────────────── */
.dev-integ-cat-section { margin-bottom: 28px; }
.dev-integ-cat-section[style*="display:none"] { display: none !important; }
.dev-integ-cat-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--dev-border);
}
.dev-integ-cat-title {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748B;
}
.dev-integ-cat-count {
    font-size: 0.68rem;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 99px;
    background: rgba(255,255,255,0.06);
    color: #64748B;
}

/* ── Grid ─────────────────────────────────────────────────── */
.dev-integ-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
}

/* ── Card ─────────────────────────────────────────────────── */
.dev-integ-card {
    background: var(--dev-card);
    border: 1px solid var(--dev-border);
    border-radius: 14px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: border-color 0.18s, box-shadow 0.18s, transform 0.15s;
    cursor: default;
}
.dev-integ-card:hover {
    border-color: rgba(255,255,255,0.14);
    box-shadow: 0 4px 18px rgba(0,0,0,0.18);
    transform: translateY(-1px);
}
.dev-integ-card-main {
    border-color: rgba(16,185,129,0.28);
    background: linear-gradient(135deg, rgba(16,185,129,0.05) 0%, var(--dev-card) 60%);
    box-shadow: 0 0 0 1px rgba(16,185,129,0.12);
}
.dev-integ-card-main:hover {
    border-color: rgba(16,185,129,0.45);
    box-shadow: 0 4px 20px rgba(16,185,129,0.12);
}
.dev-integ-card[style*="display:none"] { display: none !important; }

/* ── Card head ────────────────────────────────────────────── */
.dev-integ-card-head {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.dev-integ-icon {
    width: 38px;
    height: 38px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.dev-integ-card-head-info { flex: 1; min-width: 0; }
.dev-integ-card-name {
    font-size: 0.85rem;
    font-weight: 700;
    color: #F1F5F9;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    line-height: 1.2;
}
.dev-integ-card-cat {
    font-size: 0.68rem;
    color: #64748B;
    margin-top: 2px;
}

/* ── Card body ────────────────────────────────────────────── */
.dev-integ-card-desc {
    font-size: 0.75rem;
    color: #64748B;
    line-height: 1.5;
    flex: 1;
}

/* ── Meta row ─────────────────────────────────────────────── */
.dev-integ-card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    min-height: 18px;
}
.dev-integ-env-badge,
.dev-integ-last-sync {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.68rem;
    color: #64748B;
    background: rgba(255,255,255,0.05);
    padding: 2px 7px;
    border-radius: 5px;
    border: 1px solid var(--dev-border);
    white-space: nowrap;
}

/* ── Footer ───────────────────────────────────────────────── */
.dev-integ-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 2px;
    padding-top: 10px;
    border-top: 1px solid var(--dev-border);
}

/* ── Status dot ───────────────────────────────────────────── */
.dev-integ-status-dot {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.73rem;
    font-weight: 600;
}
.dev-integ-status-dot::before {
    content: '';
    width: 7px; height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
}
.dev-integ-status-dot.connected  { color: #34D399; }
.dev-integ-status-dot.connected::before  { background: #10B981; box-shadow: 0 0 6px #10B98166; }
.dev-integ-status-dot.disconnected { color: #94A3B8; }
.dev-integ-status-dot.disconnected::before { background: #475569; }
.dev-integ-status-dot.error      { color: #FCA5A5; }
.dev-integ-status-dot.error::before { background: #EF4444; box-shadow: 0 0 6px #EF444466; }
.dev-integ-status-dot.configuring { color: #FCD34D; }
.dev-integ-status-dot.configuring::before { background: #F59E0B; }
.dev-integ-status-dot.unused     { color: #475569; }
.dev-integ-status-dot.unused::before { background: #334155; }

/* ── Card buttons ─────────────────────────────────────────── */
.dev-integ-card-btn {
    padding: 5px 12px;
    border-radius: 7px;
    border: 1px solid var(--dev-border);
    background: rgba(255,255,255,0.05);
    color: #CBD5E1;
    font-size: 0.73rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s, border-color 0.15s;
    white-space: nowrap;
}
.dev-integ-card-btn:hover {
    background: rgba(255,255,255,0.10);
    border-color: rgba(255,255,255,0.18);
}
.dev-integ-card-btn-main {
    background: rgba(16,185,129,0.18);
    border-color: rgba(16,185,129,0.35);
    color: #34D399;
}
.dev-integ-card-btn-main:hover {
    background: rgba(16,185,129,0.28);
    border-color: rgba(16,185,129,0.55);
}

/* ── Logs section ─────────────────────────────────────────── */
.dev-integ-logs-section { margin-top: 32px; }
.dev-integ-logs-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    gap: 12px;
}
.dev-integ-logs-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88rem;
    font-weight: 700;
    color: #CBD5E1;
}
.dev-integ-logs-title .material-symbols-outlined { color: #64748B; font-size: 18px; }

/* ── Modal backdrop ───────────────────────────────────────── */
.dev-integ-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(2,8,18,0.70);
    backdrop-filter: blur(4px);
    z-index: 1200;
    opacity: 0;
    transition: opacity 0.22s;
}
.dev-integ-modal-backdrop.open { opacity: 1; }

/* ── Modal panel ──────────────────────────────────────────── */
.dev-integ-modal {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(520px, 100vw);
    background: var(--dev-surface, #0D1F38);
    border-left: 1px solid var(--dev-border);
    box-shadow: -8px 0 40px rgba(0,0,0,0.35);
    z-index: 1210;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.25s cubic-bezier(.4,0,.2,1);
    overflow: hidden;
}
.dev-integ-modal.open { transform: translateX(0); }

/* ── Modal header ─────────────────────────────────────────── */
.dev-integ-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px 16px;
    border-bottom: 1px solid var(--dev-border);
    flex-shrink: 0;
}

/* ── Modal body ───────────────────────────────────────────── */
.dev-integ-modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* ── Modal footer ─────────────────────────────────────────── */
.dev-integ-modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 14px 20px;
    border-top: 1px solid var(--dev-border);
    flex-shrink: 0;
    flex-wrap: wrap;
}

/* ── Close button ─────────────────────────────────────────── */
.dev-integ-modal-close-btn {
    width: 34px; height: 34px;
    border-radius: 8px;
    border: 1px solid var(--dev-border);
    background: rgba(255,255,255,0.04);
    color: #94A3B8;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 0.15s;
}
.dev-integ-modal-close-btn:hover { background: rgba(255,255,255,0.09); color: #F1F5F9; }
.dev-integ-modal-close-btn .material-symbols-outlined { font-size: 18px; }

/* ── Status bar ───────────────────────────────────────────── */
.dev-integ-modal-status-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 0.8rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--dev-border);
}
.dev-integ-modal-status-bar.status-connected  { background: rgba(16,185,129,0.10); border-color: rgba(16,185,129,0.25); color: #34D399; }
.dev-integ-modal-status-bar.status-disconnected { color: #94A3B8; }
.dev-integ-modal-status-bar.status-error      { background: rgba(239,68,68,0.10); border-color: rgba(239,68,68,0.25); color: #FCA5A5; }
.dev-integ-modal-status-bar.status-configuring { background: rgba(245,158,11,0.10); border-color: rgba(245,158,11,0.25); color: #FCD34D; }
.dev-integ-modal-status-bar.status-unused     { color: #475569; }
.dev-integ-modal-sep { opacity: 0.35; margin: 0 2px; }

/* ── Notice ───────────────────────────────────────────────── */
.dev-integ-modal-notice {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 10px;
    background: rgba(245,158,11,0.07);
    border: 1px solid rgba(245,158,11,0.2);
    font-size: 0.75rem;
    color: #94A3B8;
    line-height: 1.5;
}

/* ── Section title ────────────────────────────────────────── */
.dev-integ-modal-sec-title {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748B;
    margin-bottom: 10px;
}

/* ── Field grid ───────────────────────────────────────────── */
.dev-integ-modal-field-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
@media (max-width: 540px) {
    .dev-integ-modal-field-grid { grid-template-columns: 1fr; }
}

/* ── Service rows (BaaS) ──────────────────────────────────── */
.dev-integ-svc-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--dev-border);
    font-size: 0.8rem;
    color: #94A3B8;
}
.dev-integ-svc-row:last-child { border-bottom: none; }
.dev-integ-svc-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 6px;
}
.dev-integ-svc-badge.ok      { background: rgba(16,185,129,0.15); color: #34D399; }
.dev-integ-svc-badge.neutral { background: rgba(148,163,184,0.1); color: #64748B; }

/* ── Responsive adjustments ───────────────────────────────── */
@media (max-width: 900px) {
    .dev-integ-grid { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
}
@media (max-width: 640px) {
    .dev-integ-grid { grid-template-columns: 1fr 1fr; }
    .dev-integ-toolbar { flex-direction: column; align-items: stretch; }
    .dev-integ-search-wrap { min-width: unset; }
    .dev-integ-filters { flex-direction: column; }
    .dev-integ-filter { min-width: unset; width: 100%; }
}
@media (max-width: 400px) {
    .dev-integ-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   CNPJ AUTOFILL
════════════════════════════════════════════════════════════ */

/* Wrapper com ícone de estado */
.cad-cnpj-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.cad-cnpj-wrap .dev-form-input {
    padding-right: 38px;
    width: 100%;
}

/* Spinner e ícone posicionados à direita */
.cad-cnpj-spinner,
.cad-cnpj-icon {
    position: absolute;
    right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

/* Estado do campo CNPJ */
#cad-cnpj.cad-cnpj-loading {
    border-color: rgba(59,130,246,0.55) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.10);
}
#cad-cnpj.cad-cnpj-ok {
    border-color: rgba(16,185,129,0.55) !important;
    box-shadow: 0 0 0 3px rgba(16,185,129,0.08);
}
#cad-cnpj.cad-cnpj-err {
    border-color: rgba(239,68,68,0.55) !important;
    box-shadow: 0 0 0 3px rgba(239,68,68,0.08);
}

/* Mensagem de status abaixo do CNPJ */
.cad-cnpj-status {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.73rem;
    margin-top: 5px;
    line-height: 1.4;
    padding: 5px 10px;
    border-radius: 7px;
    font-weight: 500;
}
.cad-cnpj-status.loading  { color: #93C5FD; background: rgba(59,130,246,0.08); border: 1px solid rgba(59,130,246,0.18); }
.cad-cnpj-status.success  { color: #6EE7B7; background: rgba(16,185,129,0.08); border: 1px solid rgba(16,185,129,0.20); }
.cad-cnpj-status.error    { color: #FCA5A5; background: rgba(239,68,68,0.08);  border: 1px solid rgba(239,68,68,0.20); }
.cad-cnpj-status.warn     { color: #FDE68A; background: rgba(245,158,11,0.08); border: 1px solid rgba(245,158,11,0.20); }
.cad-cnpj-status .material-symbols-outlined { font-size: 14px; flex-shrink: 0; }

/* Campo auto-preenchido pela API */
.dev-form-input.cad-autofilled {
    border-color: rgba(16,185,129,0.45) !important;
    background: rgba(16,185,129,0.05) !important;
    color: #D1FAE5;
    box-shadow: 0 0 0 3px rgba(16,185,129,0.06);
    transition: border-color 0.2s, background 0.2s;
}

/* ── SCROLLBAR ──────────────────────────────────────────── */

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(120,130,150,.28); border-radius: 8px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(120,130,150,.45); background-clip: padding-box; }

/* ════════════════════════════════════════════════════════════
   RESKIN CLARO — telas detalhadas (Cadastrar, Credenciais,
   Planos, Módulos, Financeiro, Config, Edição). Override final:
   regra posterior vence; mantém layout, só troca cores p/ o
   novo design (tema claro + acento azul). NÃO muda funcionalidade.
   ════════════════════════════════════════════════════════════ */

/* área de conteúdo clara */
.dev-content { background: var(--page); color: var(--ink); }

/* —— superfícies de card → painel branco —— */
.dev-cfg-card, .dev-cfg-integ-card, .dev-edit-panel, .dev-fin-chart-card,
.dev-fin-kpi, .dev-fin-mini-kpi, .dev-fin-relatorio-card, .dev-mod-card,
.dev-plano-card, .dev-slideover, .dev-wizard-card, .dev-cfg-supa-modal,
.dev-cred-card, .dev-cred-detail-card, .dev-cred-plan-preview, .dev-cred-fin-kpi {
    background: var(--panel) !important;
    border-color: var(--border) !important;
    box-shadow: var(--shadow);
}
.dev-fin-kpi:hover, .dev-fin-relatorio-card:hover, .dev-mod-card:hover {
    background: var(--panel-2) !important;
    border-color: var(--accent-soft) !important;
}

/* —— inputs / selects / campos elevados → claro —— */
.dev-cfg-input, .dev-cfg-select, .dev-fin-select, .dev-so-input,
.dev-mods-search-wrap, .dev-mods-search, .dev-integ-search,
.dev-so-input-prefix, .dev-edit-select, .dev-edit-input, .dev-form-input {
    background: var(--panel-2) !important;
    border-color: var(--border) !important;
    color: var(--ink) !important;
}
.dev-cfg-input::placeholder, .dev-mods-search::placeholder,
.dev-integ-search::placeholder, .dev-so-input::placeholder,
.dev-form-input::placeholder, .dev-edit-input::placeholder { color: var(--muted); }
.dev-cfg-select option, .dev-fin-select option, .dev-edit-select option { background: #fff; color: var(--ink); }

/* —— cabeçalhos de tabela detalhada —— */
.dev-fin-table th, .dev-cfg-logs-table th {
    background: var(--panel-2) !important;
    color: var(--muted) !important;
    border-color: var(--border) !important;
}
.dev-fin-table td, .dev-cfg-logs-table td {
    color: var(--ink) !important;
    border-color: var(--border) !important;
}

/* —— textos: títulos/valores/nomes → tinta escura —— */
.dev-cfg-card-title, .dev-cfg-header-text h1, .dev-cfg-section-heading h2,
.dev-cfg-infra-title, .dev-cfg-backup-info-value, .dev-cfg-supa-info-value,
.dev-cfg-supa-service-name, .dev-cfg-switch-row-label, .dev-cfg-danger-row-label,
.dev-cred-detail-nome, .dev-cred-empresa-nome, .dev-cred-page-title,
.dev-cred-mod-name, .dev-cred-plan-limits strong, .dev-cred-plan-preview-nome,
.dev-cred-plan-preview-valor, .dev-cred-fin-kpi span:last-child,
.dev-fin-kpi-title, .dev-fin-kpi-value, .dev-fin-mini-val, .dev-fin-rel-title,
.dev-fin-chart-header h3, .dev-fin-empresa-name, .dev-fin-situacao, .dev-fin-title,
.dev-fin-valor, .dev-mod-nome, .dev-mods-title, .dev-module-label, .dev-plano-nome,
.dev-plano-recurso, .dev-planos-title, .dev-edit-header-title,
.dev-so-label, .dev-form-label, .dev-wizard-step-label, .dev-edit-label {
    color: var(--ink) !important;
}

/* —— textos secundários → cinza —— */
.dev-cred-page-sub, .dev-fin-subtitle, .dev-mods-subtitle, .dev-planos-subtitle,
.dev-form-hint, .dev-module-sub, .dev-cfg-section-heading p, .dev-fin-rel-sub {
    color: var(--muted) !important;
}

/* —— abas/filtros (texto) —— */
.dev-cred-tab, .dev-fin-tab, .dev-mods-filter, .dev-cfg-sidenav-item, .dev-integ-tab {
    color: var(--muted);
}
.dev-cred-tab:hover, .dev-fin-tab:hover, .dev-mods-filter:hover,
.dev-cfg-sidenav-item:hover, .dev-integ-tab:hover { color: var(--ink); }
.dev-cred-tab.active, .dev-fin-tab.active, .dev-mods-filter.active,
.dev-cfg-sidenav-item.active, .dev-integ-tab.active {
    color: var(--accent) !important;
    background: var(--chip-bg);
}

/* —— botões primários → acento azul, texto branco —— */
.dev-action-btn-primary, .dev-btn-novo-modulo, .dev-btn-novo-plano,
.dev-btn-salvar-empresa, .dev-btn-wizard-next, .dev-btn-wizard-submit,
.dev-cfg-save-btn, .dev-edit-btn-save, .dev-fin-btn-primary, .dev-so-btn-save,
.dev-integ-card-btn {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
}
.dev-action-btn-primary:hover, .dev-btn-novo-modulo:hover, .dev-btn-novo-plano:hover,
.dev-btn-salvar-empresa:hover, .dev-btn-wizard-next:hover, .dev-btn-wizard-submit:hover,
.dev-cfg-save-btn:hover, .dev-edit-btn-save:hover, .dev-fin-btn-primary:hover,
.dev-so-btn-save:hover { background: var(--accent-2) !important; }

/* —— botões secundários / neutros → claro —— */
.dev-btn-wizard-back, .dev-cfg-btn-neutral, .dev-fin-btn-secondary,
.dev-so-btn-cancel, .dev-cred-back-btn, .dev-fin-action-btn {
    background: var(--panel) !important;
    color: var(--ink) !important;
    border: 1px solid var(--border) !important;
}
.dev-btn-wizard-back:hover, .dev-cfg-btn-neutral:hover, .dev-fin-btn-secondary:hover,
.dev-so-btn-cancel:hover, .dev-cred-back-btn:hover { background: var(--panel-2) !important; }

/* —— módulos (cadastro/edição) —— */
.dev-modulo-check, .dev-edit-mod-item, .dev-cred-mod-item {
    background: var(--panel-2) !important;
    border-color: var(--border) !important;
    color: var(--ink) !important;
}
.dev-modulo-check:hover, .dev-edit-mod-item:hover, .dev-cred-mod-item:hover {
    border-color: var(--accent) !important;
}
.dev-modulo-check.checked {
    background: var(--chip-bg) !important;
    border-color: var(--accent) !important;
    color: var(--accent) !important;
}

/* —— wizard stepper / upload —— */
.dev-upload-zone { background: var(--panel-2) !important; border-color: var(--border) !important; }
