/**
 * MY FAMILY — Diseño Profesional v3.0
 * Paleta vibrante, jerarquía visual fuerte
 */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=DM+Mono:wght@400;500&display=swap');

/* ══════════════════════════════════════════════
   VARIABLES
══════════════════════════════════════════════ */
:root {
    /* Azul marca */
    --blue-50:  #eff6ff;
    --blue-100: #dbeafe;
    --blue-400: #60a5fa;
    --blue-500: #3b82f6;
    --blue-600: #2563eb;
    --blue-700: #1d4ed8;
    --blue-800: #1e40af;
    --blue-900: #1e3a8a;

    /* Emerald / verde */
    --green-400: #34d399;
    --green-500: #10b981;
    --green-600: #059669;
    --green-700: #047857;

    /* Violet */
    --violet-400: #a78bfa;
    --violet-500: #8b5cf6;
    --violet-600: #7c3aed;
    --violet-700: #6d28d9;

    /* Naranja */
    --orange-400: #fb923c;
    --orange-500: #f97316;
    --orange-600: #ea580c;

    /* Rosa */
    --rose-400: #fb7185;
    --rose-500: #f43f5e;
    --rose-600: #e11d48;

    /* Amarillo */
    --amber-400: #fbbf24;
    --amber-500: #f59e0b;
    --amber-600: #d97706;

    /* Neutros */
    --gray-50:  #f8fafc;
    --gray-100: #f1f5f9;
    --gray-200: #e2e8f0;
    --gray-300: #cbd5e1;
    --gray-400: #94a3b8;
    --gray-500: #64748b;
    --gray-600: #475569;
    --gray-700: #334155;
    --gray-800: #1e293b;
    --gray-900: #0f172a;

    /* Layout */
    --navbar-h:    64px;
    --page-bg:     #f0f4ff;       /* fondo ligeramente azulado */
    --card-bg:     #ffffff;
    --border:      #e2e8f0;

    /* Tipografía */
    --font:   'Plus Jakarta Sans', system-ui, sans-serif;
    --mono:   'DM Mono', monospace;

    /* Radios */
    --r-sm: 8px;
    --r-md: 12px;
    --r-lg: 16px;
    --r-xl: 22px;

    /* Sombras */
    --s-xs: 0 1px 3px rgba(15,23,42,.06);
    --s-sm: 0 2px 8px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);
    --s-md: 0 4px 20px rgba(15,23,42,.10), 0 2px 4px rgba(15,23,42,.04);
    --s-lg: 0 8px 40px rgba(15,23,42,.13), 0 4px 8px rgba(15,23,42,.05);
    --s-xl: 0 20px 60px rgba(15,23,42,.18);

    /* Colores semánticos */
    --success: #059669;
    --danger:  #e11d48;
    --warning: #d97706;
    --info:    #0284c7;
}

/* ══════════════════════════════════════════════
   BASE
══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font);
    font-size: .9rem;
    color: var(--gray-800);
    background: var(--page-bg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--gray-100); }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--blue-400); }

/* ══════════════════════════════════════════════
   NAVBAR — dark gradient + colorida
══════════════════════════════════════════════ */
.navbar {
    height: var(--navbar-h);
    background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 60%, #1d4ed8 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,.06);
    box-shadow: 0 4px 24px rgba(15,23,42,.35);
    padding: 0 1.5rem;
    position: sticky;
    top: 0;
    z-index: 1030;
}

/* Franja de color en la base de la navbar */
.navbar::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--blue-400), var(--violet-500), var(--green-400), var(--orange-400));
}

.navbar-brand {
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff !important;
    letter-spacing: -.3px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0;
    text-decoration: none;
}

.brand-pill {
    background: linear-gradient(135deg, var(--blue-500), var(--violet-600));
    border-radius: var(--r-md);
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    box-shadow: 0 2px 8px rgba(59,130,246,.4);
}

.brand-text-main  { display: block; line-height: 1.1; font-size: 1rem; }
.brand-text-sub   { display: block; font-size: .58rem; font-weight: 400; opacity: .6; letter-spacing: 1.5px; text-transform: uppercase; }

.navbar .nav-link {
    color: rgba(255,255,255,.75) !important;
    font-weight: 500;
    font-size: .82rem;
    padding: .42rem .8rem !important;
    border-radius: var(--r-sm);
    transition: all .15s ease;
    display: flex; align-items: center; gap: 5px;
    white-space: nowrap;
}

.navbar .nav-link i { font-size: .9rem; }

.navbar .nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,.1);
}

.navbar .nav-link.active,
.navbar .nav-item.active > .nav-link {
    color: #fff !important;
    background: rgba(255,255,255,.15);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.15);
}

/* Dropdown */
.navbar .dropdown-menu {
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--s-lg);
    padding: .5rem;
    min-width: 210px;
    background: #fff;
    animation: popIn .15s ease;
}

@keyframes popIn {
    from { opacity: 0; transform: translateY(-8px) scale(.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.navbar .dropdown-item {
    border-radius: var(--r-sm);
    font-size: .83rem;
    font-weight: 500;
    padding: .5rem .85rem;
    color: var(--gray-700);
    display: flex; align-items: center; gap: 9px;
    transition: all .12s ease;
}

.navbar .dropdown-item:hover {
    background: var(--blue-50);
    color: var(--blue-700);
    transform: translateX(2px);
}

.navbar .dropdown-item i {
    width: 18px;
    color: var(--blue-500);
}

.navbar .dropdown-divider { margin: .35rem 0; border-color: var(--gray-100); }

/* Avatar usuario */
.user-avatar {
    width: 32px; height: 32px;
    background: linear-gradient(135deg, var(--blue-500), var(--violet-600));
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; color: #fff;
    box-shadow: 0 2px 8px rgba(59,130,246,.35);
    flex-shrink: 0;
}

/* ══════════════════════════════════════════════
   FONDO Y LAYOUT
══════════════════════════════════════════════ */
.container-fluid.mt-4 {
    padding: 1.75rem 2rem;
    flex: 1;
}

/* Patrón sutil en el fondo */
body {
    background-image:
        radial-gradient(circle at 20% 20%, rgba(59,130,246,.04) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(139,92,246,.04) 0%, transparent 50%);
}

/* ══════════════════════════════════════════════
   CARDS
══════════════════════════════════════════════ */
.card {
    background: var(--card-bg);
    border: 1px solid rgba(226,232,240,.8) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--s-sm);
    transition: transform .2s ease, box-shadow .2s ease;
    overflow: hidden;
    animation: riseUp .3s ease both;
}

@keyframes riseUp {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}

.card:hover {
    box-shadow: var(--s-md);
    transform: translateY(-3px);
}

/* Stagger de entrada */
.row > [class*="col"]:nth-child(1) .card { animation-delay: .00s; }
.row > [class*="col"]:nth-child(2) .card { animation-delay: .06s; }
.row > [class*="col"]:nth-child(3) .card { animation-delay: .12s; }
.row > [class*="col"]:nth-child(4) .card { animation-delay: .18s; }

/* Headers de cards con gradientes */
.card-header {
    padding: .9rem 1.3rem;
    border-bottom: 1px solid rgba(255,255,255,.12) !important;
    font-weight: 700;
    font-size: .875rem;
    letter-spacing: -.1px;
}

.card-header.bg-primary {
    background: linear-gradient(135deg, var(--blue-800) 0%, var(--blue-600) 100%) !important;
    color: #fff;
}
.card-header.bg-success {
    background: linear-gradient(135deg, var(--green-700) 0%, var(--green-500) 100%) !important;
    color: #fff;
}
.card-header.bg-info {
    background: linear-gradient(135deg, #0369a1 0%, #0ea5e9 100%) !important;
    color: #fff;
}
.card-header.bg-warning {
    background: linear-gradient(135deg, #92400e 0%, var(--amber-500) 100%) !important;
    color: #fff;
}
.card-header.bg-danger {
    background: linear-gradient(135deg, #9f1239 0%, var(--rose-500) 100%) !important;
    color: #fff;
}
.card-header.bg-dark {
    background: linear-gradient(135deg, var(--gray-900) 0%, var(--gray-700) 100%) !important;
    color: #fff;
}
.card-header.bg-light {
    background: linear-gradient(135deg, var(--gray-100), var(--gray-50)) !important;
    color: var(--gray-700);
    border-bottom: 1px solid var(--border) !important;
}

.card-body  { padding: 1.25rem; }
.card-footer {
    background: linear-gradient(135deg, var(--gray-50), #fff);
    border-top: 1px solid var(--border);
    padding: .9rem 1.25rem;
}

/* ── Stat cards coloridas ──────────────────────────────────────────────── */
.stat-card-blue {
    background: linear-gradient(135deg, var(--blue-700) 0%, var(--blue-500) 100%);
    color: #fff; border: none !important;
}
.stat-card-green {
    background: linear-gradient(135deg, var(--green-700) 0%, var(--green-500) 100%);
    color: #fff; border: none !important;
}
.stat-card-violet {
    background: linear-gradient(135deg, var(--violet-700) 0%, var(--violet-500) 100%);
    color: #fff; border: none !important;
}
.stat-card-orange {
    background: linear-gradient(135deg, var(--orange-600) 0%, var(--amber-500) 100%);
    color: #fff; border: none !important;
}
.stat-card-rose {
    background: linear-gradient(135deg, #9f1239 0%, var(--rose-500) 100%);
    color: #fff; border: none !important;
}

.stat-card-blue, .stat-card-green,
.stat-card-violet, .stat-card-orange, .stat-card-rose {
    box-shadow: var(--s-md) !important;
    position: relative; overflow: hidden;
}

/* Círculo decorativo en stat cards */
.stat-card-blue::before, .stat-card-green::before,
.stat-card-violet::before, .stat-card-orange::before,
.stat-card-rose::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
}

.stat-card-blue::after, .stat-card-green::after,
.stat-card-violet::after, .stat-card-orange::after {
    content: '';
    position: absolute;
    bottom: -40px; left: -20px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: rgba(0,0,0,.06);
}

/* Icono en cards de estadísticas */
.stat-icon-wrap {
    width: 52px; height: 52px;
    border-radius: var(--r-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.icon-blue   { background: rgba(59,130,246,.12); color: var(--blue-600); }
.icon-green  { background: rgba(16,185,129,.12); color: var(--green-600); }
.icon-violet { background: rgba(139,92,246,.12); color: var(--violet-600); }
.icon-orange { background: rgba(249,115,22,.12); color: var(--orange-600); }
.icon-rose   { background: rgba(244,63,94,.12);  color: var(--rose-600); }
.icon-amber  { background: rgba(245,158,11,.12); color: var(--amber-600); }
.icon-white  { background: rgba(255,255,255,.2); color: #fff; }

/* ══════════════════════════════════════════════
   TABLAS
══════════════════════════════════════════════ */
.table { background: white; font-size: .875rem; margin-bottom: 0; }

.table thead th {
    background: linear-gradient(135deg, var(--gray-800), var(--gray-700));
    color: rgba(255,255,255,.85);
    font-weight: 600;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .7px;
    border: none !important;
    padding: .8rem 1rem;
    white-space: nowrap;
}

.table thead th:first-child { border-radius: 0; }

.table tbody td {
    padding: .75rem 1rem;
    vertical-align: middle;
    border-color: var(--gray-100);
    color: var(--gray-700);
}

.table-hover tbody tr {
    transition: all .12s ease;
    cursor: default;
}

.table-hover tbody tr:hover {
    background: linear-gradient(90deg, var(--blue-50), #fff) !important;
    transform: scale(1.002);
}

.table-success td { background: #f0fdf4 !important; }

/* ══════════════════════════════════════════════
   BOTONES
══════════════════════════════════════════════ */
.btn {
    font-family: var(--font);
    font-weight: 600;
    font-size: .85rem;
    letter-spacing: -.1px;
    border-radius: var(--r-md);
    padding: .5rem 1.15rem;
    border: none;
    transition: all .15s ease;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    position: relative;
    overflow: hidden;
}

/* Ripple effect */
.btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.0);
    transition: background .15s ease;
    border-radius: inherit;
}
.btn:hover::after { background: rgba(255,255,255,.08); }
.btn:active::after { background: rgba(0,0,0,.06); }

.btn:hover   { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(0,0,0,.18); }
.btn:active  { transform: translateY(0); }

.btn-primary {
    background: linear-gradient(135deg, var(--blue-700), var(--blue-500));
    color: #fff;
    box-shadow: 0 2px 8px rgba(37,99,235,.3);
}
.btn-primary:hover { background: linear-gradient(135deg, var(--blue-800), var(--blue-700)); color: #fff; }

.btn-success {
    background: linear-gradient(135deg, var(--green-700), var(--green-500));
    color: #fff;
    box-shadow: 0 2px 8px rgba(5,150,105,.3);
}
.btn-success:hover { background: linear-gradient(135deg, #14532d, var(--green-700)); color: #fff; }

.btn-danger {
    background: linear-gradient(135deg, #9f1239, var(--rose-500));
    color: #fff;
    box-shadow: 0 2px 8px rgba(225,29,72,.3);
}
.btn-danger:hover { color: #fff; }

.btn-warning {
    background: linear-gradient(135deg, #92400e, var(--amber-500));
    color: #fff;
    box-shadow: 0 2px 8px rgba(217,119,6,.3);
}
.btn-warning:hover { color: #fff; }

.btn-info {
    background: linear-gradient(135deg, #0369a1, #0ea5e9);
    color: #fff;
    box-shadow: 0 2px 8px rgba(2,132,199,.3);
}
.btn-info:hover { color: #fff; }

.btn-secondary {
    background: linear-gradient(135deg, var(--gray-700), var(--gray-500));
    color: #fff;
}
.btn-secondary:hover { color: #fff; }

.btn-outline-primary {
    border: 1.5px solid var(--blue-500) !important;
    color: var(--blue-600) !important;
    background: transparent;
}
.btn-outline-primary:hover {
    background: var(--blue-50) !important;
    color: var(--blue-700) !important;
    box-shadow: none;
    transform: none;
}

.btn-outline-secondary {
    border: 1.5px solid var(--gray-300) !important;
    color: var(--gray-600) !important;
    background: transparent;
}
.btn-outline-secondary:hover {
    background: var(--gray-100) !important;
    color: var(--gray-800) !important;
    box-shadow: none; transform: none;
}

.btn-outline-danger {
    border: 1.5px solid var(--rose-500) !important;
    color: var(--rose-600) !important;
    background: transparent;
}
.btn-outline-danger:hover {
    background: #fff1f2 !important;
    color: #9f1239 !important;
    box-shadow: none; transform: none;
}

.btn-outline-warning {
    border: 1.5px solid var(--amber-500) !important;
    color: var(--amber-600) !important;
    background: transparent;
}
.btn-outline-warning:hover {
    background: #fffbeb !important;
    box-shadow: none; transform: none;
}

.btn-lg { padding: .65rem 1.6rem; font-size: .95rem; border-radius: var(--r-md); }
.btn-sm { padding: .28rem .7rem; font-size: .78rem; border-radius: var(--r-sm); }

/* ══════════════════════════════════════════════
   FORMULARIOS
══════════════════════════════════════════════ */
.form-label {
    font-weight: 600;
    font-size: .82rem;
    color: var(--gray-700);
    margin-bottom: .4rem;
    letter-spacing: -.1px;
}

.form-control, .form-select {
    font-family: var(--font);
    font-size: .875rem;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--r-md);
    padding: .55rem .9rem;
    color: var(--gray-800);
    background: #fff;
    transition: all .15s ease;
    box-shadow: var(--s-xs);
}

.form-control:hover, .form-select:hover { border-color: var(--blue-300); }

.form-control:focus, .form-select:focus {
    border-color: var(--blue-500);
    box-shadow: 0 0 0 3px rgba(59,130,246,.15);
    outline: none;
}

.form-control[readonly] { background: var(--gray-50); color: var(--gray-500); }
.form-control-lg, .form-select-lg { padding: .7rem 1rem; font-size: .95rem; }

.input-group-text {
    background: linear-gradient(135deg, var(--gray-100), var(--gray-50));
    border: 1.5px solid var(--gray-200);
    color: var(--gray-600);
    font-weight: 700;
    font-size: .875rem;
    border-radius: var(--r-md);
}

.input-group .form-control { border-left: none; }
.input-group .input-group-text:first-child {
    border-right: none;
    border-radius: var(--r-md) 0 0 var(--r-md);
}
.input-group .form-control:last-child { border-radius: 0 var(--r-md) var(--r-md) 0; }
.input-group:focus-within .input-group-text {
    border-color: var(--blue-500);
    background: var(--blue-50);
    color: var(--blue-700);
}

.form-check-input:checked {
    background-color: var(--blue-600);
    border-color: var(--blue-600);
}

/* ══════════════════════════════════════════════
   BADGES — coloridos y pill
══════════════════════════════════════════════ */
.badge {
    font-family: var(--font);
    font-weight: 700;
    font-size: .7rem;
    letter-spacing: .2px;
    padding: .28rem .7rem;
    border-radius: 99px;
}

.bg-primary   { background: linear-gradient(135deg, var(--blue-700), var(--blue-500)) !important; }
.bg-success   { background: linear-gradient(135deg, var(--green-700), var(--green-500)) !important; }
.bg-danger    { background: linear-gradient(135deg, #9f1239, var(--rose-500)) !important; }
.bg-warning   { background: linear-gradient(135deg, #92400e, var(--amber-500)) !important; color: #fff !important; }
.bg-info      { background: linear-gradient(135deg, #0369a1, #0ea5e9) !important; }
.bg-secondary { background: linear-gradient(135deg, var(--gray-700), var(--gray-500)) !important; }
.bg-dark      { background: linear-gradient(135deg, var(--gray-900), var(--gray-700)) !important; }
.bg-light     { background: var(--gray-100) !important; color: var(--gray-700) !important; }

/* Badges con borde (soft) */
.badge-soft-blue   { background: var(--blue-50);   color: var(--blue-700);   border: 1px solid var(--blue-200);   }
.badge-soft-green  { background: #f0fdf4;           color: var(--green-700);  border: 1px solid #bbf7d0;           }
.badge-soft-red    { background: #fff1f2;           color: #9f1239;           border: 1px solid #fecdd3;           }
.badge-soft-orange { background: #fff7ed;           color: var(--orange-600); border: 1px solid #fed7aa;           }
.badge-soft-violet { background: #f5f3ff;           color: var(--violet-700); border: 1px solid #ddd6fe;           }

/* ══════════════════════════════════════════════
   ALERTAS
══════════════════════════════════════════════ */
.alert {
    border: none;
    border-left: 4px solid;
    border-radius: var(--r-md);
    font-size: .875rem;
    padding: .85rem 1.1rem;
}
.alert-success { background: #f0fdf4; border-left-color: var(--green-500); color: #14532d; }
.alert-danger  { background: #fff1f2; border-left-color: var(--rose-500);  color: #881337; }
.alert-warning { background: #fffbeb; border-left-color: var(--amber-500); color: #78350f; }
.alert-info    { background: #f0f9ff; border-left-color: #0ea5e9;          color: #0c4a6e; }
.alert-primary { background: var(--blue-50); border-left-color: var(--blue-500); color: var(--blue-800); }

/* ══════════════════════════════════════════════
   MODALES
══════════════════════════════════════════════ */
.modal-content {
    border: none;
    border-radius: var(--r-xl);
    box-shadow: var(--s-xl);
    overflow: hidden;
}
.modal-header { padding: 1.15rem 1.5rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.modal-header.bg-primary { background: linear-gradient(135deg, var(--blue-900), var(--blue-600)) !important; }
.modal-header.bg-danger  { background: linear-gradient(135deg, #9f1239, var(--rose-500)) !important; }
.modal-header.bg-success { background: linear-gradient(135deg, var(--green-700), var(--green-500)) !important; }
.modal-header.bg-warning { background: linear-gradient(135deg, #92400e, var(--amber-500)) !important; }
.modal-header .btn-close { filter: brightness(0) invert(1); opacity: .8; }
.modal-body   { padding: 1.5rem; }
.modal-footer { padding: 1rem 1.5rem; background: var(--gray-50); border-top: 1px solid var(--border); }
.modal-title  { font-weight: 700; font-size: 1rem; letter-spacing: -.2px; }
.modal.fade .modal-dialog { transform: scale(.95) translateY(-12px); }
.modal.show .modal-dialog { transform: scale(1) translateY(0); transition: transform .2s cubic-bezier(.34,1.56,.64,1); }

/* ══════════════════════════════════════════════
   PROGRESS
══════════════════════════════════════════════ */
.progress {
    background: var(--gray-100);
    border-radius: 99px;
    overflow: hidden;
    box-shadow: inset 0 1px 3px rgba(0,0,0,.06);
}
.progress-bar {
    border-radius: 99px;
    background: linear-gradient(90deg, var(--blue-600), var(--violet-500), var(--green-500));
    background-size: 200% 100%;
    animation: progressFlow 3s ease infinite;
    position: relative;
}
@keyframes progressFlow {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* ══════════════════════════════════════════════
   TIPOGRAFÍA
══════════════════════════════════════════════ */
h1 { font-size: 1.65rem; font-weight: 800; letter-spacing: -.6px; color: var(--gray-900); }
h2 { font-size: 1.35rem; font-weight: 700; letter-spacing: -.3px; }
h3 { font-size: 1.15rem; font-weight: 700; }
h4 { font-size: 1rem;    font-weight: 700; }
h5 { font-size: .9rem;   font-weight: 700; }
h6 {
    font-size: .75rem; font-weight: 700;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: .7px;
}

.text-muted   { color: var(--gray-400) !important; }
.text-primary { color: var(--blue-600) !important; }
.text-success { color: var(--green-600) !important; }
.text-danger  { color: var(--rose-600) !important; }
.text-warning { color: var(--amber-600) !important; }

.money { font-family: var(--mono); font-weight: 500; letter-spacing: -.5px; }

/* ══════════════════════════════════════════════
   BREADCRUMB
══════════════════════════════════════════════ */
.breadcrumb { background: transparent; padding: 0; margin-bottom: .75rem; font-size: .8rem; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--gray-300); }
.breadcrumb-item a { color: var(--blue-600); text-decoration: none; font-weight: 500; }
.breadcrumb-item a:hover { color: var(--blue-700); }
.breadcrumb-item.active { color: var(--gray-400); }

/* ══════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════ */
footer.footer {
    background: linear-gradient(135deg, var(--gray-900), var(--gray-800));
    padding: 1rem 2rem;
    margin-top: auto;
}
footer.footer .text-muted { color: rgba(255,255,255,.4) !important; font-size: .78rem; }
footer.footer strong { color: rgba(255,255,255,.7) !important; }
footer.footer i { color: var(--blue-400); }

/* ══════════════════════════════════════════════
   UTILIDADES
══════════════════════════════════════════════ */
hr { border-color: var(--border); opacity: 1; margin: 1rem 0; }

.shadow-sm { box-shadow: var(--s-sm) !important; }
.shadow    { box-shadow: var(--s-md) !important; }
.shadow-lg { box-shadow: var(--s-lg) !important; }

.sticky-top { top: calc(var(--navbar-h) + 1rem) !important; }
.cursor-pointer { cursor: pointer; }
.font-mono { font-family: var(--mono) !important; }
.fw-semibold { font-weight: 600 !important; }

/* Select2 */
.select2-container--bootstrap-5 .select2-selection {
    border: 1.5px solid var(--gray-200) !important;
    border-radius: var(--r-md) !important;
    font-size: .875rem; font-family: var(--font);
    box-shadow: var(--s-xs) !important;
}
.select2-container--bootstrap-5.select2-container--focus .select2-selection {
    border-color: var(--blue-500) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,.12) !important;
}
.select2-container--bootstrap-5 .select2-dropdown {
    border: 1.5px solid var(--gray-200);
    border-radius: var(--r-lg);
    box-shadow: var(--s-lg);
    font-size: .875rem; font-family: var(--font);
}
.select2-container--bootstrap-5 .select2-results__option--highlighted {
    background: var(--blue-50) !important; color: var(--blue-700) !important;
}

/* DataTables */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    border: 1.5px solid var(--gray-200);
    border-radius: var(--r-md);
    font-family: var(--font); font-size: .825rem;
    padding: .4rem .7rem; color: var(--gray-700); background: white;
}
.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--blue-500); outline: none;
    box-shadow: 0 0 0 3px rgba(59,130,246,.1);
}
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label { font-size: .825rem; color: var(--gray-500); }
.dataTables_wrapper .dataTables_paginate .paginate_button { border-radius: var(--r-sm) !important; font-size: .82rem !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
    background: linear-gradient(135deg, var(--blue-700), var(--blue-500)) !important;
    border-color: var(--blue-600) !important; color: #fff !important;
}

/* ══════════════════════════════════════════════
   FIXES — texto visible en cards blancas
══════════════════════════════════════════════ */

/*
 * Problema: algunas cards usan text-white o text-muted heredado
 * que hace el texto invisible sobre fondo blanco.
 * Solución: forzar colores oscuros en cards sin clase de color explícita.
 */

/* Cards normales (blancas) — texto siempre oscuro */
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body h1,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body h2,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body h3,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body h4,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body h5,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body p,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body span:not(.badge),
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body strong,
.card:not(.stat-card-blue):not(.stat-card-green):not(.stat-card-violet):not(.stat-card-orange):not(.stat-card-rose) .card-body small {
    color: var(--gray-800);
}

/* Títulos grandes de dinero en cards blancas */
.card:not([class*="stat-card"]) .card-body .display-4,
.card:not([class*="stat-card"]) .card-body .display-5,
.card:not([class*="stat-card"]) .card-body .display-6 {
    color: var(--gray-900) !important;
}

/* text-white SOLO aplica dentro de cards de color */
.card:not([class*="stat-card"]):not(.bg-primary):not(.bg-success):not(.bg-danger):not(.bg-warning):not(.bg-info):not(.bg-dark) .text-white {
    color: var(--gray-800) !important;
}

/* Subtítulos / descripciones en cards blancas */
.card:not([class*="stat-card"]) .card-body .text-muted {
    color: var(--gray-500) !important;
}

/* Fix específico: card con fondo blanco que tiene texto de enlace o título */
.card .card-body > h4,
.card .card-body > h5,
.card .card-body > p.text-muted {
    color: var(--gray-700);
}

/* Cards con gradiente de fondo — texto blanco OK */
.stat-card-blue *,
.stat-card-green *,
.stat-card-violet *,
.stat-card-orange *,
.stat-card-rose * {
    color: #fff !important;
}

.stat-card-blue .text-muted,
.stat-card-green .text-muted,
.stat-card-violet .text-muted,
.stat-card-orange .text-muted,
.stat-card-rose .text-muted {
    color: rgba(255,255,255,.7) !important;
}

/* ══════════════════════════════════════════════
   IMPRESIÓN
══════════════════════════════════════════════ */
@media print {
    .navbar, footer, .btn, .no-print { display: none !important; }
    .card { border: 1px solid #ddd !important; box-shadow: none !important; }
    body { background: white; font-size: 12px; }
}

/* ══════════════════════════════════════════════
   FIXES DIRECTOS — casos puntuales del dashboard
══════════════════════════════════════════════ */

/*
 * 1. "TOTAL INGRESOS" y su monto — texto invisible por herencia de color blanco.
 *    Forzar gris oscuro sobre cualquier card con fondo blanco/claro.
 */
.card-body .text-uppercase,
.card-body small.text-uppercase,
.card-body p.text-uppercase {
    color: var(--gray-500) !important;
}

/* Montos grandes dentro de cards blancas */
.card-body h2:not(.text-white),
.card-body h3:not(.text-white),
.card-body h4:not(.text-white) {
    color: var(--gray-900);
}

/* Montos con clases de color deben respetarse */
.card-body .text-success { color: var(--green-600) !important; }
.card-body .text-primary { color: var(--blue-600) !important; }
.card-body .text-danger  { color: var(--rose-600) !important; }
.card-body .text-warning { color: var(--amber-600) !important; }
.card-body .text-info    { color: #0284c7 !important; }

/*
 * 2. Card "Dashboard Ejecutivo" con texto y fondo blancos.
 *    Aplicar fondo con gradiente suave y texto oscuro.
 */
.card.border-0.shadow-sm .card-body h5:first-child,
.card.border-0.shadow-sm .card-body p.text-muted {
    color: var(--gray-700) !important;
}

/* Cards con fondo de imagen/gradiente en reportes */
.card [class*="bg-gradient"] h5,
.card [class*="bg-gradient"] p {
    color: #fff !important;
}

/* Asegurar que los h1/h2 del contenido de página sean visibles */
.container-fluid h1,
.container-fluid h2,
.container-fluid h3 {
    color: var(--gray-900);
}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 768px) {
    .container-fluid.mt-4 { padding: 1rem; }
    h1 { font-size: 1.3rem; }
    .card-body { padding: 1rem; }
    .navbar { padding: 0 1rem; }
    footer.footer { padding: .75rem 1rem; }
}