:root{
  --bg:#ffffff;
  --bg-soft:#f6f8fb;
  --text:#1f2937;
  --muted:#6b7280;
  --primary:#2b7cff;
  --primary-100:#e7f0ff;
  --border:#e5e7eb;
  --danger:#ef4444;
  --success:#22c55e;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-soft);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{text-decoration:none;color:var(--primary)}
input,select,textarea,button{font:inherit}
/* Remova cores customizadas de button para usar Bootstrap */
button{cursor:pointer}

.container{max-width:1100px;margin:0 auto;padding:24px}
.card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}

.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;background:#fff;border-bottom:1px solid var(--border)}
.brand{font-weight:700;color:var(--text)}
.userbox{color:var(--muted)}

.layout{display:flex;min-height:100vh}
.sidebar a{display:block;padding:10px 12px;border-radius:8px;color:var(--text)}
.sidebar a.active, .sidebar a:hover{background:var(--primary-100);color:var(--primary)}
.content{flex:1;padding:24px}

.footer{color:var(--muted);text-align:center}

.form-row{display:grid;grid-template-columns:180px 1fr;gap:12px;align-items:center;margin-bottom:14px}
.form-row input, .form-row textarea, .form-row select{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fff}
.form-actions{display:flex;gap:10px;margin-top:12px}

.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:10px}
.table th{font-weight:600;color:var(--muted)}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:var(--primary-100);color:white !important;font-size:12px}

/* Garantir fonte branca em todos os badges */
.badge.bg-primary,
.badge.bg-secondary,
.badge.bg-success,
.badge.bg-danger,
.badge.bg-warning,
.badge.bg-info,
.badge.bg-light {
    color: white !important;
}

/* Badge light com fundo mais escuro para melhor contraste */
.badge.bg-light {
    background-color: #6c757d !important;
}

.login-wrap{max-width:520px;margin:60px auto}
.login-card{padding:22px}
.login-title{font-size:20px;font-weight:600;margin-bottom:12px}
.error{color:var(--danger);margin-bottom:8px}

/* Complementos Bootstrap */
.navbar-brand{font-weight:700}
.nav .nav-link{color:var(--text)}
.nav .nav-link.active{background:var(--primary-100);color:var(--primary);border-radius:8px}

/* Marketing dropdown styling */
.nav-item .nav-link[data-bs-toggle="collapse"] {
    cursor: pointer;
    transition: all 0.2s ease;
}

.nav-item .nav-link[data-bs-toggle="collapse"]:hover {
    background: var(--primary-100);
    color: var(--primary);
    border-radius: 8px;
}

.nav-item .nav-link[data-bs-toggle="collapse"] .bi-chevron-down {
    transition: transform 0.2s ease;
}

.nav-item .nav-link[data-bs-toggle="collapse"][aria-expanded="true"] .bi-chevron-down {
    transform: rotate(180deg);
}

.nav-item .collapse .nav-link {
    padding: 0.5rem 0.75rem;
    font-size: 0.9rem;
    border-left: 2px solid var(--border);
    margin-left: 0.5rem;
}

.nav-item .collapse .nav-link:hover {
    border-left-color: var(--primary);
}

/* Janela de histórico mais larga (desktop até ~1000px, mobile quase toda a tela) */
.offcanvas-wide { --bs-offcanvas-width: min(95vw, 1000px); }

/* Mais altura útil para a tabela, reduzindo rolagens internas */
#historyTableWrap { max-height: calc(100vh - 220px); overflow: auto; }