/* ═══════════════════════════════════════════════════════════════
   SOPORTE TÉCNICO 2026 — Clean Light Theme (Coursue-inspired)
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900&display=swap');

/* ─── Design Tokens ─────────────────────────────────────────── */
:root {
    /* Dashboard Vibrant Brand */
    --primary: #2563eb;       /* Royal Blue */
    --primary-dark: #1d4ed8;
    --primary-light: #60a5fa;
    --primary-ultra: #eff6ff; /* Soft blue for active backgrounds */
    /* very light tint for hover bg */
    --primary-mid: rgba(37, 99, 235, 0.12);

    /* Accent chips */
    --chip-purple: #ede9fe;
    --chip-purple-txt: #7c3aed;
    --chip-blue: #dbeafe;
    --chip-blue-txt: #1d4ed8;
    --chip-green: #dcfce7;
    --chip-green-txt: #15803d;
    --chip-gray: #f1f5f9;
    --chip-gray-txt: #64748b;

    /* Surfaces */
    --body-bg: #f8fafc;
    --sidebar-bg: #ffffff;
    --navbar-bg: #ffffff;
    --card-bg: #ffffff;

    /* Text */
    --text: #0f172a;
    --text-muted: #64748b;
    --text-light: #94a3b8;
    --text-xlight: #cbd5e1;

    /* Borders */
    --border: #e2e8f0;
    --border-light: #f1f5f9;

    /* Semantic */
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;

    /* Shadows — Soft and diffused like reference */
    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.02);
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
    --shadow-md: 0 8px 24px rgba(149, 157, 165, 0.1);
    --shadow-lg: 0 12px 32px rgba(149, 157, 165, 0.15);

    /* Shape - Bubbly/Rounded like reference */
    --r-xs: 4px;
    --r-sm: 6px;
    --r-md: 8px;
    --r-lg: 12px;
    --r-xl: 16px;
    --r-full: 9999px;

    /* Sidebar */
    --sidebar-w: 220px;

    /* Easing */
    --ease: cubic-bezier(0.4, 0, 0.2, 1);
    --dur: 0.2s;
}

/* ─── Reset / Base ───────────────────────────────────────────── */
*,
*::before,
*::after {
    box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
span,
div,
td,
th,
label,
input,
select,
button,
textarea {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif !important;
}

body {
    background: var(--body-bg) !important;
    color: var(--text) !important;
    font-size: 14px;
    line-height: 1.6;
}

/* ─── Navbar / Header ────────────────────────────────────────── */
.navbar.fixed-top {
    background: var(--navbar-bg) !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: var(--shadow-xs) !important;
    backdrop-filter: none !important;
    height: 90px;
}

/* Hamburger icon */
.navbar.fixed-top .menu-button svg rect,
.navbar.fixed-top .menu-button-mobile svg rect {
    fill: var(--text-muted);
}

/* User dropdown */
.navbar.fixed-top .user .btn .name {
    font-weight: 600;
    color: var(--text) !important;
    font-size: 0.875rem;
}

.navbar.fixed-top .user img {
    width: 36px;
    height: 36px;
    border-radius: 50%;

    object-fit: cover;
    transition: border-color var(--dur) var(--ease);
}

.navbar.fixed-top .user:hover img {
    border-color: var(--primary-light);
}

.dropdown-menu {
    border: 1px solid var(--border) !important;
    border-radius: var(--r-md) !important;
    box-shadow: var(--shadow-lg) !important;
    padding: 6px !important;
}

.dropdown-item {
    border-radius: var(--r-sm) !important;
    padding: 8px 14px !important;
    font-weight: 500 !important;
    color: var(--text) !important;
    font-size: 0.875rem !important;
    transition: all var(--dur) var(--ease) !important;
}

.dropdown-item:hover {
    background: var(--primary-ultra) !important;
    color: var(--primary-dark) !important;
}

.header-icon {
    color: var(--text-muted) !important;
    transition: color var(--dur) var(--ease) !important;
}

.header-icon:hover {
    color: var(--primary) !important;
}

/* ─── Sidebar ────────────────────────────────────────────────── */
.menu {
    background: var(--sidebar-bg) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-sm) !important;
    width: var(--sidebar-w) !important;
    padding-top: 16px !important;
    border-radius: var(--r-lg) !important;
    /* Floating card: not full-height, sits below header with gap */
    position: fixed !important;
    top: 115px !important;
    /* header height + gap */
    left: 16px !important;
    bottom: 16px !important;
    /* gap from bottom */
    height: 654px !important;
    overflow-y: auto !important;
    z-index: 0 !important;
    /* Transición suave para ocultar/mostrar */
    transition: transform 0.3s var(--ease), opacity 0.3s var(--ease) !important;
    transform: translateX(0) !important;
    opacity: 1 !important;
}

/* ─── Sidebar oculto (botón hamburguesa) ─────────────────────── */
/* El JS de Dore agrega main-hidden al body cuando se oculta el menú principal */
#app-container.main-hidden .menu {
    transform: translateX(calc(-1 * var(--sidebar-w) - 32px)) !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* main se expande cuando el sidebar está oculto */
#app-container.main-hidden main {
    margin-left: 24px !important;
}

/* También cubrir sub-hidden + main-hidden combinado */
#app-container.menu-sub-hidden.main-hidden .menu,
#app-container.menu-default.main-hidden .menu {
    transform: translateX(calc(-1 * var(--sidebar-w) - 32px)) !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

#app-container.menu-sub-hidden.main-hidden main,
#app-container.menu-default.main-hidden main {
    margin-left: 24px !important;
}

.menu .main-menu {
    background: transparent !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    position: relative !important;
    left: auto !important;
}

.menu .main-menu .scroll {
    padding-right: 0 !important;
    height: auto !important;
}

/* Section labels like "OVERVIEW", "INVENTORY" */
.menu-section-label {
    padding: 20px 20px 6px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--text-light);
    display: block;
}

.menu .main-menu ul {
    padding: 8px 12px;
    margin-bottom: 0;
}

.menu .main-menu ul li a {
    color: var(--text-muted) !important;
    font-size: 0.9rem !important;
    font-weight: 500;
    padding: 12px 20px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px;
    height: auto !important;
    border-radius: var(--r-full) !important;
    margin-bottom: 4px;
    transition: all var(--dur) var(--ease) !important;
    text-decoration: none !important;
    background: transparent !important;
}

.menu .main-menu ul li a:hover {
    background: var(--primary-ultra) !important;
    color: var(--primary-dark) !important;
}

.menu .main-menu ul li.active a {
    background: var(--primary) !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.35) !important;
}

/* Remove old active indicator bar */
.menu .main-menu ul li.active::after {
    display: none !important;
}

.menu .main-menu ul li a i {
    font-size: 1.25rem !important;
    width: 24px;
    height: 24px;
    line-height: 24px;
    margin: 0 !important;
    text-align: center;
    display: inline-block !important;
    flex-shrink: 0;
    opacity: 0.7;
    transition: opacity var(--dur) var(--ease);
}

.menu .main-menu ul li a span {
    font-size: 0.9rem !important;
    text-align: left !important;
    display: inline-block !important;
    line-height: 1 !important;
}

.menu .main-menu ul li.active a i,
.menu .main-menu ul li a:hover i {
    opacity: 1;
}

@media (min-width: 1440px) {
    main {
        margin-left: calc(var(--sidebar-w) + 56px) !important;
        margin-right: 32px !important;
        padding-top: 115px !important;
        margin-top: 0px;
        transition: margin-left 0.3s var(--ease);
    }
}

@media (min-width: 768px) {
    main {
        margin-left: calc(var(--sidebar-w) + 48px) !important;
        margin-right: 24px !important;
        padding-top: 115px !important;
        margin-top: 0px;
        transition: margin-left 0.3s var(--ease);
    }
}

/* ─── Cards ──────────────────────────────────────────────────── */
.card {
    background: var(--card-bg) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    transition: box-shadow var(--dur) var(--ease),
        transform var(--dur) var(--ease);
    overflow: hidden;
}

.card:hover {
    box-shadow: var(--shadow-md) !important;
}

a.card {
    text-decoration: none !important;
    display: block;
    cursor: pointer;
}

a.card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg) !important;
}

.card-body {
    padding: 24px !important;
}

.card-title {
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: var(--text-muted) !important;
    margin-bottom: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

/* ─── Stat / Summary Cards ───────────────────────────────────── */
/* Style 1: Colored chip icon + number + label (like the reference) */
.stat-card {
    border-radius: var(--r-lg) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-sm) !important;
    background: var(--card-bg) !important;
    display: flex;
    flex-direction: column;
    padding: 24px !important;
    gap: 12px;
    transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
    position: relative;
    overflow: hidden;
}

.stat-card:hover {
    box-shadow: var(--shadow-md) !important;
    transform: translateY(-2px);
}

/* Remove pseudo-elements from old dark style */
.stat-card::after,
.stat-card::before {
    display: none !important;
}

.stat-card .stat-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--r-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
    margin-bottom: 0 !important;
}

.stat-card .stat-label {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--text-muted);
    margin-bottom: 2px;
    opacity: 1;
}

.stat-card .stat-value {
    font-size: 2.2rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -1.5px;
    color: var(--text) !important;
    margin-bottom: 0 !important;
    position: relative;
    z-index: 1;
}

/* Chip color variants */
.stat-card-primary .stat-icon {
    background: var(--chip-purple);
    color: var(--chip-purple-txt);
}

.stat-card-info .stat-icon {
    background: var(--chip-blue);
    color: var(--chip-blue-txt);
}

.stat-card-success .stat-icon {
    background: var(--chip-green);
    color: var(--chip-green-txt);
}

.stat-card-warning .stat-icon {
    background: #fef9c3;
    color: #a16207;
}

.stat-card-purple .stat-icon {
    background: #fae8ff;
    color: #9333ea;
}

.stat-card-danger .stat-icon {
    background: #fee2e2;
    color: #dc2626;
}

/* Accent left border on active stat cards */
.stat-card-primary {
    border-left: 3px solid var(--primary) !important;
}

.stat-card-info {
    border-left: 3px solid #3b82f6 !important;
}

.stat-card-success {
    border-left: 3px solid #22c55e !important;
}

/* Legacy .acceso (fallback for old HTML) */
.acceso {
    font-size: 2rem !important;
    color: var(--primary) !important;
    background: none !important;
    -webkit-text-fill-color: var(--primary) !important;
    display: block;
    margin-bottom: 12px;
}

.card .lead {
    font-size: 2rem !important;
    font-weight: 800 !important;
    color: var(--text) !important;
    letter-spacing: -1px;
    margin-bottom: 0 !important;
}

.card .card-text {
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: var(--text-muted) !important;
    margin-bottom: 8px !important;
}

/* ─── Hero Banner Card (like the purple banner in reference) ── */
.hero-banner {
    background: linear-gradient(130deg, var(--primary-dark) 0%, var(--primary) 50%, #30B18B 100%) !important;
    border: none !important;
    border-radius: var(--r-xl) !important;
    position: relative;
    overflow: hidden;
    color: #fff !important;
    padding: 32px 36px !important;
    margin-bottom: 24px;
}

.hero-banner::after {
    content: '✦';
    position: absolute;
    right: 32px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 5rem;
    opacity: 0.15;
    pointer-events: none;
}

.hero-banner h2 {
    font-size: 1.6rem !important;
    font-weight: 800 !important;
    color: #fff !important;
    letter-spacing: -0.5px;
    margin-bottom: 6px;
    line-height: 1.3;
}

.hero-banner p {
    color: rgba(255, 255, 255, 0.8) !important;
    font-size: 0.875rem !important;
    margin-bottom: 20px;
}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
    border-radius: var(--r-full) !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    padding: 8px 18px !important;
    letter-spacing: 0.2px !important;
    transition: all var(--dur) var(--ease) !important;
    text-transform: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    border: none !important;
}

.btn-primary {
    background: var(--primary) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3) !important;
}

.btn-primary:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 16px rgba(37, 99, 235, 0.4) !important;
    color: #fff !important;
}

.btn-outline-secondary {
    border: 1.5px solid var(--border) !important;
    color: var(--text-muted) !important;
    background: transparent !important;
}

.btn-outline-secondary:hover {
    background: var(--border-light) !important;
    color: var(--text) !important;
}

.btn-sm {
    padding: 5px 12px !important;
    font-size: 0.76rem !important;
    border-radius: var(--r-xs) !important;
}

/* ─── Tables ─────────────────────────────────────────────────── */
.table {
    color: var(--text) !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
}

.table thead th {
    background: #fafafa !important;
    border-top: none !important;
    border-bottom: 1px solid var(--border) !important;
    font-weight: 700 !important;
    font-size: 0.72rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: var(--text-light) !important;
    padding: 12px 16px !important;
    white-space: nowrap;
}

.table thead th:first-child {
    border-radius: var(--r-xs) 0 0 0;
}

.table thead th:last-child {
    border-radius: 0 var(--r-xs) 0 0;
}

.table tbody tr td {
    border: none !important;
    border-bottom: 1px solid var(--border-light) !important;
    padding: 13px 16px !important;
    vertical-align: middle !important;
    font-size: 0.875rem !important;
    color: var(--text) !important;
}

.table-bordered {
    border: none !important;
}

.table tbody tr {
    transition: background var(--dur) var(--ease);
}

.table tbody tr:hover td {
    background: var(--primary-ultra) !important;
}

.table tbody tr:last-child td {
    border-bottom: none !important;
}

/* ─── Status Badges ──────────────────────────────────────────── */
.badge-status {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: var(--r-full);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.2px;
}

.badge-status-active {
    background: var(--chip-green);
    color: var(--chip-green-txt);
}

.badge-status-inactive {
    background: var(--chip-gray);
    color: var(--chip-gray-txt);
}

/* ─── Category Chips (like FRONT END, UI/UX DESIGN in ref) ─── */
.chip {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: var(--r-full);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

.chip-purple {
    background: var(--chip-purple);
    color: var(--chip-purple-txt);
}

.chip-blue {
    background: var(--chip-blue);
    color: var(--chip-blue-txt);
}

.chip-green {
    background: var(--chip-green);
    color: var(--chip-green-txt);
}

/* ─── DataTables Overrides ───────────────────────────────────── */
.dataTables_wrapper {
    padding-top: 8px !important;
}

.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    border: 1.5px solid var(--border) !important;
    border-radius: var(--r-full) !important;
    padding: 6px 14px !important;
    font-size: 0.8rem !important;
    color: var(--text) !important;
    background: #fff !important;
    outline: none !important;
    transition: all var(--dur) var(--ease) !important;
}

.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(42, 121, 167, 0.12) !important;
}

.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_info {
    font-size: 0.8rem !important;
    color: var(--text-muted) !important;
    font-weight: 500 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: var(--r-sm) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    padding: 5px 11px !important;
    margin: 0 2px !important;
    color: var(--text-muted) !important;
    border: 1.5px solid transparent !important;
    transition: all var(--dur) var(--ease) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--primary-ultra) !important;
    color: var(--primary-dark) !important;
    border-color: var(--primary-mid) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: var(--primary) !important;
    color: white !important;
    border-color: transparent !important;
    box-shadow: 0 4px 10px rgba(42, 121, 167, 0.3) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover {
    color: var(--text-xlight) !important;
}

/* ─── Forms ──────────────────────────────────────────────────── */
.form-control {
    border-radius: var(--r-sm) !important;
    border: 1.5px solid var(--border) !important;
    padding: 10px 14px !important;
    font-size: 0.875rem !important;
    color: var(--text) !important;
    background: #fff !important;
    transition: all var(--dur) var(--ease) !important;
}

.form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(42, 121, 167, 0.12) !important;
    outline: none !important;
}

.form-control::placeholder {
    color: var(--text-light) !important;
}

label {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    color: var(--text-muted) !important;
    margin-bottom: 6px !important;
    display: block;
}

select.form-control {
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
}

/* ─── Filter Card accent ─────────────────────────────────────── */
.filter-card {
    border-left: 3px solid var(--primary) !important;
    background: #fafbff !important;
}

.filter-card .card-title {
    color: var(--primary-dark) !important;
}

/* ─── Alerts ─────────────────────────────────────────────────── */
.alert {
    border-radius: var(--r-md) !important;
    border: none !important;
    font-weight: 500 !important;
    font-size: 0.875rem !important;
}

/* ─── Login Page ─────────────────────────────────────────────── */
body.background {
    background: var(--body-bg) !important;
}

body.background .fixed-background {
    display: none;
}

.auth-card {
    border-radius: var(--r-xl) !important;
    overflow: hidden;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-lg) !important;
    background: #fff !important;
    backdrop-filter: none !important;
}

.auth-card .image-side {
    background: linear-gradient(130deg, var(--primary-dark) 0%, var(--primary) 55%, #30B18B 100%) !important;
    padding: 56px 48px !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
}

.auth-card .image-side::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
}

.auth-card .image-side::after {
    content: '';
    position: absolute;
    bottom: -60px;
    left: -20px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
}

.auth-card .image-side p.text-white.h2 {
    font-size: 1.6rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.5px !important;
    color: #fff !important;
    position: relative;
    z-index: 1;
    margin-bottom: 10px !important;
}

.auth-card .image-side p.white {
    color: rgba(255, 255, 255, 0.75) !important;
    font-size: 0.875rem !important;
    position: relative;
    z-index: 1;
}

.auth-card .form-side {
    background: #fff !important;
    padding: 56px 48px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.auth-card .form-side .logo-single-img {
    height: 44px;
    width: auto;
    display: block;
    margin-bottom: 28px;
    object-fit: contain;
}

.auth-card .form-side h6 {
    font-size: 1.6rem !important;
    font-weight: 800 !important;
    color: var(--text) !important;
    letter-spacing: -0.5px !important;
    margin-bottom: 4px !important;
}

.auth-card .form-side h6::after {
    content: 'Ingresa tus credenciales para continuar';
    display: block;
    font-size: 0.82rem;
    font-weight: 400;
    color: var(--text-muted);
    letter-spacing: 0;
    margin-top: 4px;
    margin-bottom: 28px;
}

.form-group.has-float-label input {
    padding: 22px 16px 8px !important;
    border: 1.5px solid var(--border) !important;
    border-radius: var(--r-md) !important;
    background: #f8fafc !important;
    transition: all var(--dur) var(--ease) !important;
}

.form-group.has-float-label input:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(42, 121, 167, 0.1) !important;
    background: #fff !important;
}

.form-group.has-float-label span {
    position: absolute;
    top: 14px;
    left: 16px;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    color: var(--text-light) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    pointer-events: none;
}

#btn-login {
    width: 100%;
    justify-content: center !important;
    padding: 13px 24px !important;
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    border-radius: var(--r-md) !important;
    background: var(--primary) !important;
    box-shadow: 0 6px 20px rgba(42, 121, 167, 0.35) !important;
}

#btn-login:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 28px rgba(42, 121, 167, 0.45) !important;
}

.custom-control-label {
    font-size: 0.82rem !important;
    color: var(--text-muted) !important;
    cursor: pointer;
}

#footer.page-footer {
    margin-top: 32px !important;
    background: #000000 !important;
    color: #ffffff !important;
    border-top: 1px solid #111111 !important;
    padding: 0 !important;
    transition: all 0.3s var(--ease) !important;
}

.footer-inner {
    padding: 20px 32px 20px 240px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    transition: padding 0.3s var(--ease) !important;
}

#app-container.main-hidden .footer-inner {
    padding-left: 32px !important;
}

#app-container.menu-sub-hidden.main-hidden .footer-inner,
#app-container.menu-default.main-hidden .footer-inner {
    padding-left: 32px !important;
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.footer-brand-icon {
    width: 30px;
    height: 30px;
    background: var(--primary-ultra);
    border-radius: var(--r-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}

.footer-brand-text {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--text-muted);
}

.footer-copy {
    font-size: 0.78rem;
    color: var(--text-light);
}

.footer-year-badge {
    background: var(--primary-ultra);
    color: var(--primary);
    padding: 3px 10px;
    border-radius: var(--r-full);
    font-size: 0.72rem;
    font-weight: 700;
    border: 1px solid rgba(42, 121, 167, 0.2);
}

/* ─── Loading Spinner ────────────────────────────────────────── */
body.show-spinner::after {
    border: 3px solid rgba(42, 121, 167, 0.15) !important;
    border-top-color: var(--primary) !important;
    width: 34px !important;
    height: 34px !important;
}

/* ─── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar {
    width: 5px;
    height: 5px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(42, 121, 167, 0.35);
}

/* ─── Animations ─────────────────────────────────────────────── */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.card {
    animation: fadeInUp 0.35s var(--ease) both;
}

.row .col-md-4:nth-child(1) .card,
.row .col-md-4:nth-child(1)>a>.card {
    animation-delay: 0.04s;
}

.row .col-md-4:nth-child(2) .card,
.row .col-md-4:nth-child(2)>a>.card {
    animation-delay: 0.08s;
}

.row .col-md-4:nth-child(3) .card,
.row .col-md-4:nth-child(3)>a>.card {
    animation-delay: 0.12s;
}

.row .col-lg-6:nth-child(1) .card {
    animation-delay: 0.16s;
}

.row .col-lg-6:nth-child(2) .card {
    animation-delay: 0.20s;
}

.row .col-lg-12 .card {
    animation-delay: 0.08s;
}

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width: 768px) {
    .footer-inner {
        padding-left: 20px;
    }

    .auth-card .image-side {
        display: none;
    }

    .auth-card .form-side {
        padding: 36px 24px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   EMIL KOWALSKI ANIMATIONS — Spring Physics & Micro-interactions
   Principios: spring easing, press feedback, hover lift,
   stagger entrance, y micro-interacciones fluidas.
   ═══════════════════════════════════════════════════════════════ */

:root {
    /* Spring easings — la firma de Emil Kowalski */
    --spring:        cubic-bezier(0.34, 1.56, 0.64, 1);   /* bouncy, overshoots */
    --spring-gentle: cubic-bezier(0.25, 0.46, 0.45, 0.94); /* smooth deceleration */
    --spring-snappy: cubic-bezier(0.47, 1.64, 0.41, 0.8);  /* fast bounce */

    /* Duraciones */
    --dur-fast:   0.15s;
    --dur-normal: 0.25s;
    --dur-slow:   0.4s;
}

/* ─── Entrance: reemplaza el fadeInUp plano con spring ─────── */
@keyframes springIn {
    0%   { opacity: 0; transform: translateY(16px) scale(0.97); }
    60%  { opacity: 1; transform: translateY(-3px) scale(1.005); }
    100% { opacity: 1; transform: translateY(0)   scale(1); }
}

@keyframes slideInLeft {
    0%   { opacity: 0; transform: translateX(-12px); }
    60%  { opacity: 1; transform: translateX(2px); }
    100% { opacity: 1; transform: translateX(0); }
}

@keyframes popIn {
    0%   { opacity: 0; transform: scale(0.85); }
    65%  { opacity: 1; transform: scale(1.04); }
    100% { opacity: 1; transform: scale(1); }
}

@keyframes countUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.card {
    animation: springIn var(--dur-slow) var(--spring) both;
}

/* ─── Card hover lift (Emil's signature) ────────────────────── */
.card {
    transition:
        transform var(--dur-normal) var(--spring),
        box-shadow var(--dur-normal) var(--spring-gentle),
        border-color var(--dur-fast) var(--ease) !important;
    will-change: transform;
}

.card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 16px 40px rgba(37, 99, 235, 0.1), 0 4px 12px rgba(0,0,0,0.06) !important;
}

/* Stat cards tienen un lift más pronunciado */
.stat-card:hover {
    transform: translateY(-5px) scale(1.01) !important;
    box-shadow: 0 20px 48px rgba(37, 99, 235, 0.14), 0 6px 16px rgba(0,0,0,0.07) !important;
}

/* ─── Botones — press feedback (spring scale) ───────────────── */
.btn {
    transition:
        background var(--dur-fast) var(--ease),
        color var(--dur-fast) var(--ease),
        border-color var(--dur-fast) var(--ease),
        transform var(--dur-fast) var(--spring),
        box-shadow var(--dur-normal) var(--spring-gentle) !important;
    will-change: transform;
}

.btn:active {
    transform: scale(0.95) !important;
    transition-duration: 0.08s !important;
}

.btn-primary:hover {
    transform: translateY(-2px) scale(1.01) !important;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.35) !important;
}

.btn-primary:active {
    transform: scale(0.96) translateY(0) !important;
}

/* ─── Links / nav items ──────────────────────────────────────── */
a {
    transition: color var(--dur-fast) var(--ease),
                opacity var(--dur-fast) var(--ease) !important;
}

/* ─── Inputs — focus con spring ─────────────────────────────── */
.form-control {
    transition:
        border-color var(--dur-fast) var(--ease),
        box-shadow var(--dur-normal) var(--spring-gentle),
        background var(--dur-fast) var(--ease),
        transform var(--dur-fast) var(--spring) !important;
}

.form-control:focus {
    transform: scale(1.005) !important;
}

/* ─── Chips / badges — popIn ─────────────────────────────────── */
.badge-status,
.chip {
    transition:
        transform var(--dur-fast) var(--spring),
        box-shadow var(--dur-fast) var(--spring-gentle) !important;
    animation: popIn 0.3s var(--spring) both;
    will-change: transform;
}

.badge-status:hover,
.chip:hover {
    transform: scale(1.06) !important;
}

/* ─── Tabla rows ─────────────────────────────────────────────── */
.table tbody tr {
    transition:
        background var(--dur-fast) var(--ease),
        transform var(--dur-fast) var(--spring) !important;
}

.table tbody tr:hover {
    transform: translateX(2px) !important;
}

/* ─── Sidebar menu items ─────────────────────────────────────── */
#sidebar-container .nav-item a,
.sub-menu .nav-item a,
ul.list-unstyled .nav-item a {
    transition:
        color var(--dur-fast) var(--ease),
        background var(--dur-fast) var(--ease),
        transform var(--dur-fast) var(--spring),
        padding-left var(--dur-normal) var(--spring-gentle) !important;
}

#sidebar-container .nav-item a:hover,
.sub-menu .nav-item a:hover {
    transform: translateX(3px) !important;
}

/* ─── Navbar / header ────────────────────────────────────────── */
.navbar {
    transition: box-shadow var(--dur-normal) var(--spring-gentle) !important;
}

/* ─── Dropdown animation ─────────────────────────────────────── */
.dropdown-menu {
    animation: springIn 0.22s var(--spring) both;
    transform-origin: top center;
}

/* ─── Modal spring entrance ──────────────────────────────────── */
.modal-dialog {
    animation: springIn 0.3s var(--spring) both;
}

/* ─── Stat value counter animation ──────────────────────────── */
.stat-value {
    animation: countUp 0.5s var(--spring-gentle) both;
    animation-delay: 0.2s;
    display: inline-block;
    will-change: transform, opacity;
}

/* ─── Stagger más refinado para las cards ───────────────────── */
.row .col-md-4:nth-child(1) .card,
.row .col-md-4:nth-child(1) > a > .card  { animation-delay: 0.04s; }
.row .col-md-4:nth-child(2) .card,
.row .col-md-4:nth-child(2) > a > .card  { animation-delay: 0.10s; }
.row .col-md-4:nth-child(3) .card,
.row .col-md-4:nth-child(3) > a > .card  { animation-delay: 0.16s; }
.row .col-lg-6:nth-child(1) .card        { animation-delay: 0.22s; }
.row .col-lg-6:nth-child(2) .card        { animation-delay: 0.28s; }
.row .col-lg-12 .card                    { animation-delay: 0.08s; }

/* ─── Botones en tabla — estilo texto ───────────────────────── */
/*
   Aplica a todos los .btn-sm y .btn-xs dentro de celdas <td>.
   Sin borde, sin fondo — sólo texto con color semántico y un
   subrayado al hover. Limpio y legible en filas densas.
*/
td .btn,
td .btn-sm,
td .btn-xs {
    border: none !important;
    box-shadow: none !important;
    padding: 3px 10px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    border-radius: var(--r-xs) !important;
    letter-spacing: 0.1px;
    text-decoration: none !important;
    transition:
        color var(--dur-fast) var(--ease),
        background var(--dur-fast) var(--ease),
        opacity var(--dur-fast) var(--ease),
        transform var(--dur-fast) var(--spring) !important;
}

td .btn:hover,
td .btn-sm:hover,
td .btn-xs:hover {
    background: transparent !important;
    box-shadow: none !important;
    opacity: 0.7;
}

td .btn:active,
td .btn-sm:active,
td .btn-xs:active {
    transform: scale(0.94) !important;
}

/* Colores semánticos con fondo suave */
td .btn-outline-primary,
td .btn-primary,
td a.btn-outline-primary,
td a.btn-primary {
    background: var(--chip-blue) !important;
    color: var(--chip-blue-txt) !important;
}

td .btn-outline-secondary,
td .btn-secondary,
td a.btn-outline-secondary,
td a.btn-secondary {
    background: var(--chip-gray) !important;
    color: var(--chip-gray-txt) !important;
}

td .btn-outline-success,
td .btn-success,
td a.btn-outline-success,
td a.btn-success {
    background: var(--chip-green) !important;
    color: var(--chip-green-txt) !important;
}

td .btn-outline-danger,
td .btn-danger,
td a.btn-outline-danger,
td a.btn-danger {
    background: #fee2e2 !important;
    color: #dc2626 !important;
}

td .btn-outline-warning,
td .btn-warning,
td a.btn-outline-warning,
td a.btn-warning {
    background: #fef3c7 !important;
    color: #b45309 !important;
}

/* Hover — todos vuelven a transparente manteniendo color oscuro */
td .btn:hover,
td .btn-sm:hover,
td .btn-xs:hover,
td a.btn:hover {
    background: transparent !important;
    color: var(--text) !important;
    opacity: 0.75;
}

/* ─── Reduce motion — accesibilidad ─────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}