/* ============================================================
   Sistema de Consentimientos LOPDP — Intelectum
   ============================================================ */

:root {
    --primary:    #1a3a5c;
    --primary-dk: #122840;
    --accent:     #e8a020;
    --success:    #198754;
    --danger:     #dc3545;
    --light-bg:   #f4f6f9;
    --card-shadow: 0 2px 8px rgba(0,0,0,.10);
}

body {
    background-color: var(--light-bg);
    font-family: 'Segoe UI', system-ui, sans-serif;
    color: #333;
}

/* ── Navbar ─────────────────────────────────────────────── */
.navbar-main {
    background-color: #e8edf5;
    box-shadow: 0 2px 6px rgba(0,0,0,.10);
    border-bottom: 2px solid #c5d0df;
}
.navbar-main .navbar-brand,
.navbar-main .nav-link,
.navbar-main .navbar-text {
    color: var(--primary) !important;
}
.navbar-main .nav-link:hover { color: var(--accent) !important; }

/* ── Sidebar (panel) ─────────────────────────────────────── */
.sidebar {
    min-height: calc(100vh - 56px);
    background-color: var(--primary-dk);
    padding-top: 1rem;
}
.sidebar .nav-link {
    color: #cdd8e3;
    border-radius: 6px;
    margin: 2px 8px;
    padding: 8px 14px;
    transition: background .15s, color .15s;
}
.sidebar .nav-link:hover,
.sidebar .nav-link.active {
    background-color: var(--primary);
    color: #fff;
}
.sidebar .nav-link i { width: 20px; margin-right: 6px; }

/* ── Cards ───────────────────────────────────────────────── */
.card {
    border: none;
    border-radius: 10px;
    box-shadow: var(--card-shadow);
}
.card-header-primary {
    background-color: var(--primary);
    color: #fff;
    border-radius: 10px 10px 0 0 !important;
    padding: .85rem 1.25rem;
}

/* ── Stat cards (dashboard) ──────────────────────────────── */
.stat-card {
    border-left: 5px solid var(--primary);
    border-radius: 8px;
}
.stat-card.accent  { border-left-color: var(--accent); }
.stat-card.success { border-left-color: var(--success); }
.stat-card.danger  { border-left-color: var(--danger); }
.stat-card .stat-number { font-size: 2rem; font-weight: 700; color: var(--primary); }

/* ── Badges estado consentimiento ───────────────────────── */
.badge-aceptado { background-color: var(--success); color: #fff; }
.badge-revocado { background-color: var(--danger);  color: #fff; }
.badge-pendiente{ background-color: #6c757d;        color: #fff; }

/* ── Página pública (index / verificar) ─────────────────── */
.public-hero {
    background: #e8edf5;
    color: var(--primary);
    padding: 3rem 1rem;
    text-align: center;
    border-bottom: 2px solid #c5d0df;
}
.public-hero h1 { font-size: 1.8rem; font-weight: 700; color: var(--primary); }
.search-box {
    max-width: 480px;
    margin: 0 auto;
}

/* ── Tabla de consentimientos del colaborador ───────────── */
.consent-card {
    border-radius: 10px;
    border: 1px solid #dee2e6;
    margin-bottom: 1rem;
    overflow: hidden;
    box-shadow: var(--card-shadow);
}
.consent-card .consent-header {
    background-color: var(--primary);
    color: #fff;
    padding: .75rem 1rem;
    font-weight: 600;
}
.consent-card .consent-body { padding: 1rem; }
.consent-card .consent-legal {
    font-size: .85rem;
    color: #555;
    background: #f8f9fa;
    border-radius: 6px;
    padding: .75rem 1rem;
    max-height: 120px;
    overflow-y: auto;
    border: 1px solid #e0e0e0;
    margin-bottom: .75rem;
}

/* ── Botones ─────────────────────────────────────────────── */
.btn-primary-custom {
    background-color: var(--primary);
    border-color: var(--primary);
    color: #fff;
}
.btn-primary-custom:hover {
    background-color: var(--primary-dk);
    border-color: var(--primary-dk);
    color: #fff;
}
.btn-accent {
    background-color: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

/* ── Footer ──────────────────────────────────────────────── */
footer {
    background-color: var(--primary-dk);
    color: #8fa8c0;
    font-size: .8rem;
    text-align: center;
    padding: .75rem;
    margin-top: 2rem;
}
