body {
    margin: 0;
    padding-top: 80px;
    min-height: 100vh;
    position: relative;
    background-color: #dde3ea;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
}

:root {
    --fusion-primary: #0a3d62;
    --fusion-secondary: #00a6d6;
    --fusion-accent: #2abf88;
    --fusion-bg: #eef7ff;
    --fusion-surface: #ffffff;
    --fusion-text: #223242;
    --fusion-title: #0a3d62;
    --fusion-subtitle: #4b6378;
    --fusion-table-wrapper-bg: #ffffff;
    --fusion-table-head-bg: #0a3d62;
    --fusion-table-row-bg: #ffffff;
    --fusion-table-row-alt-bg: #f4f7fb;
    --fusion-sidebar-bg: #ffffff;
    --fusion-sidebar-profile-bg: #f8fafc;
    --fusion-sidebar-text: #0a3d62;
    --fusion-sidebar-active: #2abf88;
    --fusion-sidebar-hover: #e5f1ff;
    --fusion-radius: 18px;
    --fusion-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
    --fusion-font: system-ui;
    --fusion-gym-icon-url: url('/img/logo.png');
}

/* fondo atenuado */
body::before {
    content: "";
    position: fixed;
    inset: 0;

    background-image: var(--fusion-gym-icon-url);
    background-repeat: repeat;
    background-position: center;
    background-size: 10%;

    opacity: 0.15;    /* 🔥 transparencia */

    z-index: -1;
}



html {
    scroll-behavior: smooth;
    scroll-padding-top: 100px;    /* Ajustá el valor según la altura de tu navbar */
}

/* Card futurista */
.card-cyber {
    background: rgba(10, 15, 30, 0.8);
    border: 1px solid #0ff;
    box-shadow: 0 0 20px #0ff, inset 0 0 10px #0ff;
    border-radius: 12px;
    backdrop-filter: blur(6px);
    padding: 30px;
}

/* Texto de título neón */
.neon-text {
    color: #0ff;
    text-shadow: 0 0 8px #0ff, 0 0 15px #0ff;
    font-weight: bold;
    letter-spacing: 2px;
}

/* Labels estilo Terminal */
.cyber-label {
    color: #a8c8ff;
    font-weight: 600;
    text-shadow: 0 0 4px #4ac7ff;
}

.cyber-input {
    background: #ffffff;
    border: 1px solid #d1d9e6;
    color: #0a1f44;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 0.95rem;
    transition: all 0.25s ease-in-out;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Efecto hover */
.cyber-input:hover {
    border-color: #3fa9f5;
    /* celeste deportivo */
}

/* Efecto focus (cuando escribís) */
.cyber-input:focus {
    outline: none;
    border-color: #1e90ff;
    /* azul fusion */
    box-shadow: 0 0 0 3px rgba(30, 144, 255, 0.15);
    background-color: #ffffff;
}

/* Placeholder más elegante */
.cyber-input::placeholder {
    color: #9aa3b2;
    font-size: 0.9rem;
}


/* Ajuste responsive */
@media (max-width: 480px) {
    .card-cyber {
        padding: 20px;
    }
}

/* ================= LOGIN CYBERPUNK ================= */

/* Card futurista */
.card-cyber {
    background: rgba(10, 15, 30, 0.8);
    border: 1px solid #0ff;
    box-shadow: 0 0 20px #0ff, inset 0 0 10px #0ff;
    border-radius: 12px;
    backdrop-filter: blur(6px);
    padding: 30px;
}

/* Texto de título neón */
.neon-text {
    color: #0ff;
    text-shadow: 0 0 8px #0ff, 0 0 15px #0ff;
    font-weight: bold;
    letter-spacing: 2px;
}

/* Labels estilo Terminal */
.cyber-label {
    color: #a8c8ff;
    font-weight: 600;
    text-shadow: 0 0 4px #4ac7ff;
}

/* Inputs futuristas */
.cyber-input {
    background-color: rgba(0, 10, 20, 0.7);
    border: 1px solid #4ac7ff;
    color: #e7f3ff;
    border-radius: 6px;
}

.cyber-input:focus {
    outline: none;
    border-color: #0ff;
    box-shadow: 0 0 10px #0ff;
    background-color: rgba(0, 20, 40, 0.9);
}

/* Ajuste responsive */
@media (max-width: 480px) {
    .card-cyber {
        padding: 20px;
    }
}

/* ========================= */
/*     NAVBAR CYBERPUNK     */
/* ========================= */

.navbar-cyberpunk {
    background: rgba(5, 5, 5, 0.85) !important;
    backdrop-filter: blur(6px);

    border-bottom: 2px solid #00eaff;
    box-shadow:
        0 0 8px #00eaff,
        0 0 15px rgba(0, 234, 255, 0.5);

    font-family: "Orbitron", sans-serif;
    letter-spacing: 1px;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

/* ---------- LOGO ---------- */
.navbar-brand img {
    height: 48px;
    filter: drop-shadow(0 0 6px rgba(0, 234, 255, 0.6));
}

/* ---------- LINKS ---------- */
.navbar-cyberpunk .nav-link {
    color: #c8f8ff !important;
    transition: 0.2s ease;
    font-size: 0.95rem;
    text-shadow: 0 0 4px rgba(0, 234, 255, 0.4);
}

.navbar-cyberpunk .nav-link:hover,
.navbar-cyberpunk .nav-link.active {
    color: #00eaff !important;
    text-shadow:
        0 0 8px #00eaff,
        0 0 20px rgba(0, 234, 255, 0.7);
    transform: translateX(5px);
    /* opcional — da efecto de movimiento */
}


/* ---------- BOTÓN HAMBURGUESA ---------- */
.navbar-toggler {
    border-color: #00eaff !important;
    box-shadow: 0 0 5px #00eaff;
}

.navbar-toggler-icon {
    filter: drop-shadow(0 0 6px #00eaff);
}

/* ---------- EFECTO SCANLINE SUAVE ---------- */
.navbar-cyberpunk:before {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(to bottom,
            rgba(255, 255, 255, 0.03) 0,
            rgba(255, 255, 255, 0.03) 1px,
            transparent 2px);
    pointer-events: none;
    opacity: 0.25;
}

/* ================================
   CONTENIDO PRINCIPAL
================================ */
.main-content {
    padding: 30px 20px;
    transition: margin-left 0.35s ease;
}

/* Desktop / Tablet */
@media (min-width: 768px) {
    .main-content {
        margin-left: 260px;        /* ancho del sidebar */
    }
}

/* Mobile */
@media (max-width: 767px) {
    .main-content {
        margin-left: 0;
    }
}

/* ===============================
   CONTENEDOR DATATABLE (EXTERNO)
================================ */
.container-cyberpunk {
    background: linear-gradient(145deg,
            rgba(8, 15, 35, 0.95),
            rgba(5, 10, 25, 0.95));
    border-radius: 20px;
    padding: 30px;
    border: 1px solid rgba(0, 255, 255, 0.35);
    box-shadow:
        0 0 30px rgba(0, 255, 255, 0.25),
        inset 0 0 20px rgba(0, 255, 255, 0.08);
}

/* Separación vertical */
.container-cyberpunk+.container-cyberpunk {
    margin-top: 30px;
}

/* Mobile */
@media (max-width: 767px) {
    .container-cyberpunk {
        padding: 20px 15px;
        border-radius: 14px;
    }
}

/* Animación */
@keyframes cyberFade {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.table-wrapper-cyber {
    background: rgba(85, 92, 83, 0.975);
    border-radius: 16px;
    padding: 20px;
    box-shadow:
        0 0 20px rgba(0, 255, 255, 0.15),
        inset 0 0 15px rgba(0, 255, 255, 0.08);
}

.btn-cyber-sm {
    padding: 6px 12px;
    font-size: 14px;
    border-radius: 6px;
    border: 1px solid;
    transition: 0.25s ease;
}

/* ===============================
   BOTONES ACCIÓN CYBER
================================ */

.btn-cyber-action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    background: transparent;
    border: 1px solid;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.25s ease;
}

/* ===============================
   DATA TABLE BUTTONS – CYBERPUNK
================================ */

.btn-copy {
    background: transparent !important;
    border: 1px solid #f0ad4e !important;
    color: #f0ad4e !important;
}

.btn-copy:hover {
    background: #f0ad4e !important;
    color: #1a1200 !important;
    box-shadow: 0 0 15px rgba(240, 173, 78, 0.8);
}

/* ===== EXCEL ===== */
.btn-excel {
    background: transparent !important;
    border: 1px solid #5cff72 !important;
    color: #5cff72 !important;
}

.btn-excel:hover {
    background: #5cff72 !important;
    color: #001a05 !important;
    box-shadow: 0 0 15px rgba(92, 255, 114, 0.8);
}

/* ===== PDF ===== */
.btn-pdf {
    background: transparent !important;
    border: 1px solid #ff2e63 !important;
    color: #ff2e63 !important;
}

.btn-pdf:hover {
    background: #ff2e63 !important;
    color: #1a0008 !important;
    box-shadow: 0 0 15px rgba(255, 46, 99, 0.8);
}

/* ===== PRINT ===== */
.btn-print {
    background: transparent !important;
    border: 1px solid #00aaff !important;
    color: #00aaff !important;
}

.btn-print:hover {
    background: #00aaff !important;
    color: #00131a !important;
    box-shadow: 0 0 15px rgba(0, 170, 255, 0.8);
}

.btn-copy,
.btn-excel,
.btn-pdf,
.btn-print {
    transition: all 0.25s ease;
    border-radius: 6px;
}

.dt-buttons .btn i {
    font-size: 1.2rem;
}

.dt-buttons .btn {
    padding: 6px 12px;
}

/* NUEVO */
.btn-cyber-new {
    color: #0d6efd;
    /* azul Bootstrap */
    border-color: #0d6efd;
}

.btn-cyber-new:hover {
    background: #0d6efd;
    color: #ffffff;
    box-shadow: 0 0 15px rgba(13, 110, 253, 0.8);
}

/* VOLVER */
.btn-cyber-back {
    color: #00ff88;
    border-color: #00ff88;
}

.btn-cyber-back:hover {
    background: #00ff88;
    color: #000;
    box-shadow: 0 0 15px rgba(0, 255, 136, 0.8);
}

.btn-edit {
    color: #00eaff;
    border-color: #00eaff;
}

.btn-edit:hover {
    background: #00eaff;
    color: #000;
    box-shadow: 0 0 12px #00eaff;
}

.btn-delete {
    color: #ff4c4c;
    border-color: #ff4c4c;
}

.btn-delete:hover {
    background: #ff4c4c;
    color: #000;
    box-shadow: 0 0 12px #ff4c4c;
}

/* ===============================
   ACCIONES DATATABLE
================================ */

td.acciones {
    display: flex;
    gap: 8px;
    justify-content: center;
    align-items: center;
    white-space: nowrap;
}

.btn-edit {
    background: transparent;
    border: 1px solid #28a745;
    /* verde bootstrap */
    color: #28a745;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 14px;
    transition: all 0.2s ease;
}

.btn-edit:hover {
    background: #28a745;
    color: #ffffff;
    box-shadow: 0 0 10px rgba(40, 167, 69, 0.7);
}

.btn-password {
    background: transparent;
    border: 1px solid #ffc107;
    /* amarillo bootstrap */
    color: #ffc107;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 14px;
    transition: all 0.2s ease;
}

.btn-password:hover {
    background: #ffc107;
    color: #000000;
    box-shadow: 0 0 10px rgba(255, 193, 7, 0.7);
}

/* BOTÓN ELIMINAR */
.btn-delete {
    background: transparent;
    border: 1px solid #ff4d4d;
    color: #ff4d4d;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 14px;
    transition: all 0.2s ease;
}

.btn-delete:hover {
    background: #ff4d4d;
    color: #000;
    box-shadow: 0 0 10px rgba(255, 77, 77, 0.8);
}

/* BOTÓN COBRAR */
.btn-cobrar {
    background: transparent;
    border: 2px solid #0d6efd;
    color: #0d6efd;
    border-radius: 8px;
    padding: 5px 12px;
    transition: all 0.2s ease;
}

.btn-cobrar:hover {
    background: #0d6efd;
    color: #fff;
    box-shadow: 0 0 10px #0d6efd;
    transform: scale(1.05);
}

/* BOTÓN CONFIRMAR */
.btn-confirmar {
    background: transparent;
    border: 2px solid #ffc107;
    color: #ffc107;
    border-radius: 8px;
    padding: 5px 12px;
    transition: all 0.2s ease;
}

.btn-confirmar:hover {
    background: #ffc107;
    color: #000;
    box-shadow: 0 0 10px #ffc107;
    transform: scale(1.05);
}

/* ICONO PAGADO */
.estado-pagado {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: #22c55e;
    font-weight: bold;
    transition: all 0.2s ease;
}

.estado-pagado:hover {
    transform: scale(1.1);
    text-shadow: 0 0 8px #22c55e;
}

.btn:active {
    transform: scale(0.95);
}

/* ===============================
   TABLA INTERNA — ESTILO CLARO FUSION
================================ */

table.dataTable {
    background-color: #ffffff !important;
    color: #0a1f44 !important;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* Encabezado */
table.dataTable thead {
    background: #1e90ff !important;
    color: #ffffff !important;
}

table.dataTable thead th {
    background: transparent !important;
    border-bottom: none !important;
    text-align: center;
    font-weight: 600;
}

/* Filas */
table.dataTable tbody tr {
    background-color: #ffffff !important;
    transition: background-color 0.25s ease;
}

table.dataTable tbody tr:nth-child(even) {
    background-color: #f4f7fb !important;
}

table.dataTable tbody tr:hover {
    background-color: #e6f0ff !important;
}

/* Celdas */
table.dataTable td {
    background-color: transparent !important;
    color: #0a1f44 !important;
    border-color: rgba(10, 61, 98, 0.12) !important;
    vertical-align: middle;
    text-align: center;
}

/* Controles superiores */
.dataTables_wrapper {
    color: #0a1f44;
}

/* Buscador y select */
.dataTables_filter input,
.dataTables_length select {
    background-color: #ffffff !important;
    color: #0a1f44 !important;
    border: 1px solid #1e90ff !important;
    border-radius: 8px;
    padding: 6px 10px;
}

/* Paginación */
.dataTables_paginate .paginate_button {
    color: #0a3d62 !important;
}

.dataTables_paginate .paginate_button.current {
    background: #1e90ff !important;
    color: #ffffff !important;
    border-radius: 6px;
}

/* FILA IMPAGO */
.fila-impago {
    background-color: rgba(220, 53, 69);    /* rojo suave */
    transition: all 0.2s ease;
    border-left: 5px solid #dc3545;
}

/* FILA PENDIENTE */
.fila-pendiente {
    background-color: rgba(255, 193, 7);    /* amarillo suave */
    transition: all 0.2s ease;
    border-left: 5px solid #ffc107;
}

/* FILA PAGADO */
.fila-pagado {
    background-color: rgba(26, 137, 85);    /* verde suave */
    transition: all 0.2s ease;
    border-left: 5px solid #198754;
}

/* HOVER GENERAL */
tr:hover {
    transform: scale(1.01);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

table.dataTable tbody tr.fila-impago>td {
    background-color: rgba(220, 53, 69, 0.2) !important;
}

table.dataTable tbody tr.fila-pendiente>td {
    background-color: rgba(255, 193, 7, 0.2) !important;
}

table.dataTable tbody tr.fila-pagado>td {
    background-color: rgba(25, 135, 84, 0.2) !important;
}

.btn-activo {
    box-shadow: 0 0 10px currentColor;
    transform: scale(1.05);
}

.filtros-card {
    background-color: #dfecf9;
    border-radius: 12px;
}

.disabled-link {
    opacity: 0.5;
    cursor: not-allowed;
}

.disabled-link:hover {
    opacity: 0.7;
}
/* ===============================
   DATATABLES RESPONSIVE CONTROL
   Mobile + Tablet
================================ */

@media (max-width: 991px) {

    td.dt-control {
        text-align: center;
        vertical-align: middle;
        cursor: pointer;
        padding: 12px !important;
    }

    td.dt-control::before {
        content: "▸";
        font-size: 1.7rem;
        color: #1e90ff;
        background: rgba(30, 144, 255, 0.15);
        padding: 6px 12px;
        border-radius: 10px;
        box-shadow: 0 0 6px rgba(30, 144, 255, 0.4);
        display: inline-block;
        transition: all 0.25s ease;
    }

    tr.dt-hasChild td.dt-control::before {
        content: "▾";
        color: #0a3d62;
        background: rgba(10, 61, 98, 0.15);
        box-shadow: 0 0 6px rgba(10, 61, 98, 0.4);
    }

    td.dt-control:hover::before {
        transform: scale(1.1);
    }
}

/* Neon pulse */
@keyframes pulseNeon {
    0% {
        box-shadow: 0 0 6px currentColor;
    }

    50% {
        box-shadow: 0 0 14px currentColor;
    }

    100% {
        box-shadow: 0 0 6px currentColor;
    }
}

/* ===== OVERLAY FUTURISTA ===== */
.overlay-cyberpunk {
    position: absolute;
    inset: 0;
    background: linear-gradient(rgba(5, 5, 5, 0.85),
            rgba(10, 10, 10, 0.70));
    mask-image: radial-gradient(circle at center, black 70%, transparent 100%);
    background-blend-mode: overlay;
    z-index: 1;
}


/* ----------------------------------
   BOTÓN CYBERPUNK
---------------------------------- */

.btn-cyber {
    background: transparent;
    border: 2px solid #00eaff;
    color: #00eaff;
    padding: 8px 22px;
    font-weight: 600;
    border-radius: 8px;
    transition: 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-shadow: 0 0 8px #00eaff;
}

.btn-cyber:hover {
    background: #00eaff;
    color: #000;
    box-shadow: 0 0 18px #00eaff;
}

/* ================================ */
/*         EFECTO NEÓN TEXTO        */
/* ================================ */

/* Subtítulo visible y neón */
.neon-subtitle-soft {
    color: #00eaff;
    opacity: 0.95;
    font-size: 1.2rem;
    text-shadow: 0 0 8px #00eaff;
    margin-top: -8px;
}

/* ----------------------- */
/* TITULOS NEON SUPERIORES */
/* ----------------------- */
.neon-title-cyberpunk {
    font-size: 3rem;
    color: #00eaff;
    text-shadow: 0 0 10px #00eaff, 0 0 20px #00eaff;
}

.neon-subtitle-cyber {
    font-size: 2rem;
    color: #161315;
}

/* Se activa SOLO cuando el slide está visible */
.carousel-item.active .neon-title {
    animation: neon-flicker 4s infinite;
}

.neon-title {
    font-family: "Orbitron", sans-serif;
    font-size: 4rem;
    color: #00eaff;
    text-shadow:
        0 0 5px #00eaff,
        0 0 10px #00eaff,
        0 0 20px #00eaff,
        0 0 40px rgba(0, 234, 255, 0.8);
    opacity: 1;
}

@keyframes neon-flicker {

    0%,
    100% {
        opacity: 1;
    }

    92% {
        opacity: .8;
    }

    93% {
        opacity: .3;
    }

    94% {
        opacity: 1;
    }
}


/* Se activa cuando el slide está visible */
.carousel-item.active .hero-content {
    animation: fadeSlideUp 1.2s ease forwards;
}

/* ================================ */
/*       RESPONSIVE MOBILE          */
/* ================================ */
@media (max-width: 480px) {

    .neon-title {
        font-size: 2rem;
    }

    .hero-subtitle {
        font-size: 1rem;
    }

    .btn-hero {
        padding: 10px 20px;
    }
}

#preview {
    margin-top: 20px;
    max-width: 200px;
    max-height: 200px;
}

.divider {
    height: 2px;
    width: 100%;
    background: linear-gradient(90deg, transparent, #00f0ff, transparent);
    margin: 20px 0;
}

.position-relative {
    width: 100%;            /* Asegúrate de que cada input ocupe todo el ancho del contenedor */
    margin-bottom: 15px;    /* Añade espacio entre los campos */
}

input {
    width: 100%;    /* Ajusta el ancho de los inputs al contenedor */
}

.is-invalid {
    border-color: #dc3545;
    background-color: #f8d7da;
}

.is-valid {
    border-color: #28a745;
    background-color: #d4edda;
}


/* Ocultar el input original */
.file-input {
    display: none;
}

/* Estilo del label personalizado */
.custom-file-label {
    display: inline-block;
    padding: 10px 20px;
    background-color: #007bff;      /* Color de fondo personalizado */
    color: white;                   /* Color del texto */
    border: 1px solid #007bff;      /* Borde */
    border-radius: 5px;               /* Bordes redondeados */
    cursor: pointer;                 /* Cambiar el cursor al pasar el mouse */
    text-align: center;
    transition: background-color 0.3s ease;    /* Animación suave */
}

/* Cambiar el color al pasar el mouse */
.custom-file-label:hover {
    background-color: #0056b3;    /* Color más oscuro */
}

/* Cambiar el color cuando el archivo está seleccionado */
.file-input:valid+.custom-file-label {
    background-color: #28a745;    /* Verde */
    border-color: #28a745;
    color: white;
}

.cyber-form {
    max-width: 900px;
    margin: 110px auto 60px;
    padding: 35px 40px;
    background: radial-gradient(circle at top, #08152a, #040814);
    border-radius: 18px;
    border: 1px solid rgba(0, 240, 255, 0.35);
    box-shadow:
        0 0 25px rgba(0, 240, 255, 0.15),
        inset 0 0 20px rgba(0, 240, 255, 0.05);
}

.cyber-form h1 {
    color: #5c09f7;
    text-shadow: 0 0 12px rgba(0, 240, 255, 0.9);
    margin-bottom: 10px;
}

.cyber-form h3 {
    color: #00f0ff;
    margin-top: 20px;
}

.cyber-form h5 {
    color: #3205ae;
    font-size: 0.95rem;
}

/* ===== INPUTS MODERNOS DE FUSION (compatible con Bootstrap) ===== */

.form-control {
    background: #ffffff;
    border: 1px solid #d1d9e6;
    color: #0a1f44;
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 0.95rem;
    transition: all 0.25s ease-in-out;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Hover */
.form-control:hover {
    border-color: #3fa9f5;
}

/* Focus (cuando escribís) */
.form-control:focus {
    outline: none;
    border-color: #1e90ff;
    box-shadow: 0 0 0 3px rgba(30, 144, 255, 0.15);
    background-color: #ffffff;
}

/* Placeholder elegante */
.form-control::placeholder {
    color: #9aa3b2;
    font-size: 0.9rem;
}

/* ===== ESTADOS DE VALIDACIÓN (Vue + Bootstrap) ===== */

/* Campo válido */
.form-control.is-valid {
    border-color: #28a745 !important;
    box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.12);
}

/* Campo inválido */
.form-control.is-invalid {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.12);
}

/* Mensajes de feedback más modernos */
.valid-feedback {
    font-size: 0.85rem;
    color: #28a745;
}

.invalid-feedback {
    font-size: 0.85rem;
    color: #dc3545;
}

.cyber-form .valid-tooltip {
    background: rgba(0, 240, 255, 0.9);
    color: #00151f;
    font-weight: bold;
}

.cyber-form .invalid-tooltip {
    background: rgba(255, 43, 214, 0.95);
    color: #fff;
}

.file-input {
    cursor: pointer;
}

.custom-file-label {
    display: none;
}

.cyber-form img.img-thumbnail {
    background: #050b1c;
    border: 1px solid #00f0ff;
    box-shadow: 0 0 10px rgba(0, 240, 255, 0.6);
    margin-top: 10px;
}

.cyber-form .btn {
    border-radius: 12px;
    padding: 10px 22px;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Grabar */
.cyber-form .btn-primary {
    background: transparent;
    border: 1px solid #00f0ff;
    color: #00f0ff;
    box-shadow: 0 0 10px rgba(0, 240, 255, 0.6);
}

.cyber-form .btn-primary:hover {
    background: #00f0ff;
    color: #00121a;
}

/* Volver */
.cyber-form .btn-success {
    background: transparent;
    border: 1px solid #00ff9d;
    color: #00ff9d;
    box-shadow: 0 0 10px rgba(0, 255, 157, 0.6);
}

.cyber-form .btn-success:hover {
    background: #00ff9d;
    color: #00150c;
}

.input-highlight {
    background-color: #0f172a;    /* fondo oscuro tipo cyber */
    color: #00ffcc;    /* color llamativo */
    font-weight: bold;
    border: 2px solid #00ffcc;
    text-align: left;
}

.input-highlight:focus {
    outline: none;
    box-shadow: 0 0 10px #00ffcc;
}

.input-total {
    background-color: #111827;
    color: #22c55e;    /* verde éxito */
    font-size: 18px;
    font-weight: bold;
    border: 2px solid #22c55e;
    text-align: right;
}

.input-warning {
    background-color: #111827;
    color: #f59e0b;    /* amarillo */
    font-weight: bold;
}

.card {
    border-radius: 12px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.card:hover {
    transform: scale(1.05);
    box-shadow: 0 0 15px rgba(0, 255, 200, 0.4);
}

.card h4,
.card h3 {
    margin: 0;
    font-weight: bold;
}

/* ================================
   LABELS CYBERPUNK
================================ */

.cyber-form label {
    color: #9efcff;
    font-weight: 600;
    margin-bottom: 6px;
    display: inline-block;
    text-shadow: 0 0 6px rgba(0, 240, 255, 0.6);
}

@media (max-width: 768px) {
    .cyber-form {
        padding: 25px 20px;
        margin-top: 90px;
    }
}

/* ============================= */
/* FOOTER — ESTILO CYBERPUNK    */
/* ============================= */

.footer-cyber {
    background: linear-gradient(135deg, #0a0a0f, #12121c, #0a0a0f);
    color: #eee;
    padding-top: 50px;
    padding-bottom: 20px;
    margin-top: auto;
    border-top: 2px solid #ff009d;
    box-shadow: 0 0 25px #ff009d50;
    text-align: center;
}

/* GRID */
.footer-contenido {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 30px;
    padding-bottom: 40px;
}

/* Títulos con glow */
.footer-title-neon {
    font-size: 1.3rem;
    margin-bottom: 15px;
    color: #ff009d;
    text-shadow:
        0 0 4px #ff009d,
        0 0 10px #ff009d,
        0 0 16px #ff009d;
}

/* Texto */
.footer-text,
.footer-info li {
    opacity: 0.9;
    color: #d6d6d6;
    line-height: 1.6;
}

/* ENLACES */
.footer-links li {
    list-style: none;
    margin: 6px 0;
}

.footer-links a {
    color: #c8f8ff !important;
    transition: 0.2s ease;
    font-size: 0.95rem;
    text-shadow: 0 0 4px rgba(0, 234, 255, 0.4);
}

.footer-links a:hover {
    color: #00eaff !important;
    text-shadow:
        0 0 8px #00eaff,
        0 0 20px rgba(0, 234, 255, 0.7);
    transform: translateX(5px);
    /* opcional — da efecto de movimiento */
}

/* ================================
   BOTÓN HAMBURGUESA (mejorado)
================================ */
.btn-sidebar-toggle {
    position: fixed;
    top: 18px;
    left: 18px;
    background: rgba(0, 255, 255, 0.15);
    border: 1px solid rgba(0, 255, 255, 0.35);
    color: #00eaff;
    padding: 8px 11px;
    border-radius: 10px;
    font-size: 22px;
    cursor: pointer;
    z-index: 11000;
    box-shadow: 0 0 12px rgba(0, 255, 255, 0.4);
    transition: all 0.2s ease;
}

.btn-sidebar-toggle:hover {
    background: rgba(0, 255, 255, 0.25);
    box-shadow: 0 0 18px rgba(0, 255, 255, 0.7);
}

/* ================================
   PERFIL USUARIO — Avatar dentro del sidebar
================================ */
/* Evita conflictos */
.sidebar-profile {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 25px 0;
    text-align: center;
}

.sidebar-user {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 25px 0;
    text-align: center;
    overflow: hidden;
    /* evita que la imagen se salga */
}

/* Avatar pequeño */
.sidebar-avatar {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 50%;
    border: 3px solid #ff6a00;
}

/* Nombre */
.sidebar-username {
    margin-top: 10px;
    color: #0a3d62;
    font-size: 16px;
    font-weight: 600;
}

/* Responsive avatar */
@media (max-width: 768px) {
    .sidebar-avatar {
        width: 55px;
        height: 55px;
    }
}

/* ================================
   MENÚ
================================ */
.sidebar-menu {
    flex-grow: 1;
    list-style: none;
    padding: 15px;
    margin: 0;
}

/* ================================
   BOTÓN LOGOUT
================================ */
.sidebar-logout {
    position: absolute;
    bottom: 25px;
    width: 100%;
    text-align: center;
}

.logout-btn {
    background: linear-gradient(135deg, #e84118, #c23616);
    color: white;
    border: none;
    padding: 11px 18px;
    width: 85%;
    border-radius: 8px;
    cursor: pointer;
    font-size: 16px;
    font-weight: bold;
    transition: 0.25s ease;
    box-shadow: 0 0 12px rgba(255, 60, 0, 0.4);
}

.logout-btn:hover {
    background: linear-gradient(135deg, #ff4c24, #b4200f);
    box-shadow: 0 0 15px rgba(255, 70, 20, 0.7);
}

/* ================================
   RESPONSIVE
================================ */
@media (max-width: 768px) {
    .sidebar {
        width: 230px;
    }

    .sidebar-avatar {
        width: 72px;
        height: 72px;
    }

    .btn-sidebar-toggle {
        top: 12px;
        left: 12px;
        padding: 6px 9px;
    }
}

@media (max-width: 576px) {

    /* El botón hamburguesa baja para no chocar con el logo */
    .btn-sidebar-toggle {
        top: 65px;
        left: 16px;
        transform: scale(0.95);
    }

    .sidebar {
        width: 210px;
    }

    .sidebar-menu li a {
        font-size: 15px;
        padding: 10px 18px;
    }
}


/* ICONOS REDES */
.footer-social img {
    width: 32px;
    margin: 0 8px;
    filter: drop-shadow(0 0 6px #00eaff);
    transition: 0.3s;
}

.footer-social img:hover {
    filter: drop-shadow(0 0 12px #ff009d);
    transform: scale(1.08);
}

/* LEGAL */
.footer-legal {
    border-top: 1px solid #00eaff40;
    padding-top: 15px;
    color: #999;
    font-size: 0.9rem;
}

.footer-legal a {
    color: #ff009d;
    text-decoration: none;
    text-shadow: 0 0 8px #ff009d60;
}

.footer-legal a:hover {
    color: #00eaff;
    text-shadow: 0 0 12px #00eaff;
}

.footer-legal-main {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 0;
}

.footer-developer {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #ff009d;
    text-decoration: none;
    font-weight: 700;
}

.footer-developer img {
    width: 150px;
    max-height: 38px;
    object-fit: contain;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.92);
}

.footer-product-brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #d8eef8;
    font-size: 0.86rem;
    font-weight: 700;
    opacity: 0.9;
}

.footer-product-brand img {
    width: 150px;
    max-height: 38px;
    object-fit: contain;
}

.global-logo-preview {
    max-width: 220px;
    max-height: 90px;
    object-fit: contain;
    background: #ffffff;
}

.global-icon-preview {
    width: 88px;
    height: 88px;
    object-fit: contain;
    background: #ffffff;
}

/* =========================================
   GLASS CARD CYBERPUNK
========================================= */

.glass-card {
    max-width: 720px;
    margin: 120px auto 80px auto;
    padding: 40px 35px;

    background: linear-gradient(145deg,
            rgba(0, 20, 35, 0.85),
            rgba(0, 10, 20, 0.75));

    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);

    border-radius: 22px;
    border: 1px solid rgba(0, 240, 255, 0.35);

    box-shadow:
        0 0 25px rgba(0, 240, 255, 0.15),
        inset 0 0 15px rgba(0, 240, 255, 0.05);
}

/* =========================================
   TITULOS
========================================= */

.glass-card h1 {
    color: #00f0ff;
    text-align: center;
    text-shadow: 0 0 12px rgba(0, 240, 255, 0.7);
    margin-bottom: 5px;
}

.glass-card h5 {
    text-align: center;
    color: #7cefff;
    font-weight: 300;
    margin-bottom: 30px;
}

.glass-card h3 {
    color: #00f0ff;
    text-align: center;
    margin-bottom: 15px;
}

/* Divider */
.divider {
    height: 1px;
    background: linear-gradient(to right, transparent, #00f0ff, transparent);
    margin-bottom: 25px;
}

/* =========================================
   LABELS
========================================= */

.cyber-form-dark label {
    color: #7cefff;
    font-weight: 500;
    margin-bottom: 6px;
    display: inline-block;
}


/* =========================================
   INPUTS
========================================= */

.cyber-form-dark .form-control,
.cyber-form-dark .form-select {
    background-color: rgba(0, 10, 20, 0.85);
    border: 1px solid rgba(0, 240, 255, 0.4);
    color: #e6fcff;
    border-radius: 12px;
}

.cyber-form-dark .form-control::placeholder {
    color: #7aaeb5;
}

/* Focus */
.cyber-form-dark .form-control:focus,
.cyber-form-dark .form-select:focus {
    border-color: #00f0ff;
    box-shadow: 0 0 10px rgba(0, 240, 255, 0.6);
    background-color: rgba(0, 10, 20, 0.95);
}

/* =========================================
   VALIDACIONES
========================================= */

.cyber-form-dark .is-valid {
    border-color: #00ff9c;
    box-shadow: 0 0 8px rgba(0, 255, 156, 0.6);
}

.cyber-form-dark .is-invalid {
    border-color: #ff3c3c;
    box-shadow: 0 0 8px rgba(255, 60, 60, 0.6);
}

/* Tooltips */
.cyber-form-dark .invalid-tooltip,
.cyber-form-dark .valid-tooltip {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}

/* =========================================
   BOTONES
========================================= */

.cyber-form-dark .btn {
    border-radius: 14px;
    padding: 12px 28px;
    font-weight: 600;
    letter-spacing: 1px;
}

.cyber-form-dark .btn-primary {
    background: transparent;
    border: 1px solid #00f0ff;
    color: #00f0ff;
}

.cyber-form-dark .btn-primary:hover {
    background: #00f0ff;
    color: #00131a;
    box-shadow: 0 0 15px rgba(0, 240, 255, 0.8);
}

.cyber-form-dark .btn-success {
    background: transparent;
    border: 1px solid #00ff9c;
    color: #00ff9c;
}

.cyber-form-dark .btn-success:hover {
    background: #00ff9c;
    color: #001a12;
    box-shadow: 0 0 15px rgba(0, 255, 156, 0.8);
}

/* =========================================
   MENSAJES DE ERROR (SIN SUPERPOSICIÓN)
========================================= */

.cyber-form-dark .invalid-feedback {
    display: block;
    margin-top: 6px;
    padding-left: 10px;

    font-size: 0.85rem;
    color: #ff5c8a;

    background: rgba(255, 92, 138, 0.15);
    border-left: 3px solid #ff5c8a;
    border-radius: 6px;

    box-shadow: 0 0 10px rgba(255, 92, 138, 0.4);
}

/* =========================================
   ICONO DE ERROR (INPUT)
========================================= */

.cyber-form-dark .form-control.is-invalid {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23ff5c8a' viewBox='0 0 16 16'%3E%3Cpath d='M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM7.002 4a1 1 0 0 0-.002 2 1 1 0 0 0 .002-2zm.998 3h-2v5h2V7z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 18px;

    padding-right: 45px;
    /* espacio para el icono */
}

/* ===============================
   BTN DANGER – CYBER STYLE
   (misma lógica que btn-primary)
================================ */

.cyber-form-dark .btn-danger {
    background: transparent;
    border: 1px solid #ff2e63;
    color: #ff2e63;
}

.cyber-form-dark .btn-danger:hover {
    background: #ff2e63;
    color: #1a0008;
    box-shadow: 0 0 15px rgba(255, 46, 99, 0.8);
}

.preview-img {
    max-width: 150px;
    border-radius: 12px;
    border: 1px solid rgba(0, 240, 255, 0.6);
    background: rgba(0, 240, 255, 0.08);
    box-shadow:
        0 0 12px rgba(0, 240, 255, 0.6),
        inset 0 0 10px rgba(0, 240, 255, 0.15);
}

.preview-img {
    animation: neonFadeIn 0.4s ease-out;
}

@keyframes neonFadeIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}
/* =========================================================
   NUEVO ESTILO MODERNO — FUSION DIGITAL
   (Sobrescribe el estilo cyberpunk anterior)
========================================================= */

/* PALETA FUSION */
:root {
    --fusion-dark: #0a0f1f;
    --fusion-blue: #0a3d62;
    --fusion-cyan: #00eaff;
    --fusion-soft: #1b2b45;
    --fusion-glass: rgba(10, 20, 40, 0.75);
}

/* Fondo general más limpio */
body {
    background: linear-gradient(180deg, #0a0f1f, #0b162a);
}

/* ======= TARJETAS MODERNAS (GLASS) ======= */
.card-cyber,
.glass-card,
.container-cyberpunk {
    background: linear-gradient(145deg,
            rgba(10, 20, 40, 0.85),
            rgba(10, 15, 30, 0.75));
    backdrop-filter: blur(12px);
    border: 1px solid rgba(0, 234, 255, 0.35);
    box-shadow:
        0 0 20px rgba(0, 234, 255, 0.12),
        inset 0 0 10px rgba(0, 234, 255, 0.05);
    border-radius: 18px;
}

/* ======= TÍTULOS MÁS ELEGANTES ======= */
.neon-title-cyberpunk,
.glass-card h1 {
    font-size: 2.8rem;
    color: var(--fusion-cyan);
    text-shadow: 0 0 10px rgba(0, 234, 255, 0.7);
}

/* ======= FORMULARIOS MODERNOS ======= */
.cyber-form,
.cyber-form-dark {
    background: linear-gradient(180deg,
            rgba(8, 18, 35, 0.9),
            rgba(5, 10, 20, 0.95));
    border-radius: 20px;
    border: 1px solid rgba(0, 234, 255, 0.3);
    box-shadow: 0 0 20px rgba(0, 234, 255, 0.15);
}

/* Inputs limpios y modernos */
.cyber-form .form-control,
.cyber-form-dark .form-control {
    background: rgba(10, 15, 30, 0.9);
    border: 1px solid rgba(0, 234, 255, 0.35);
    color: #eafcff;
    border-radius: 10px;
}

/* Focus agradable (sin blanco fuerte) */
.cyber-form .form-control:focus,
.cyber-form-dark .form-control:focus {
    background: rgba(10, 15, 30, 0.95);
    border-color: var(--fusion-cyan);
    box-shadow: 0 0 10px rgba(0, 234, 255, 0.6);
}

/* ======= BOTONES FUSION ======= */
.btn-cyber,
.cyber-form .btn-primary,
.cyber-form-dark .btn-primary {
    background: transparent;
    border: 1px solid var(--fusion-cyan);
    color: var(--fusion-cyan);
    border-radius: 12px;
    transition: 0.25s ease;
}

.btn-cyber:hover,
.cyber-form .btn-primary:hover,
.cyber-form-dark .btn-primary:hover {
    background: var(--fusion-cyan);
    color: #00141f;
    box-shadow: 0 0 15px rgba(0, 234, 255, 0.8);
}

/* Botón volver (verde Fusion) */
.cyber-form .btn-success,
.cyber-form-dark .btn-success {
    background: transparent;
    border: 1px solid #00ff9d;
    color: #00ff9d;
}

.cyber-form .btn-success:hover,
.cyber-form-dark .btn-success:hover {
    background: #00ff9d;
    color: #00150c;
}

/* ======= NAVBAR FUSION ======= */
.navbar-cyberpunk {
    background: rgba(10, 20, 40, 0.9) !important;
    backdrop-filter: blur(8px);
    border-bottom: 2px solid var(--fusion-cyan);
}

/* Links más limpios */
.navbar-cyberpunk .nav-link {
    color: #cfefff !important;
}

.navbar-cyberpunk .nav-link:hover,
.navbar-cyberpunk .nav-link.active {
    color: var(--fusion-cyan) !important;
    transform: translateX(3px);
}

/* ======= TABLAS MÁS MODERNAS ======= */
table.dataTable {
    background-color: #081122 !important;
    border-radius: 12px;
}

table.dataTable thead {
    background: #00eaff !important;
}

.form-check-input:checked {
    background-color: #0509f5;
    border-color: #0e19f4;
}

/* ======= FOOTER FUSION ======= */
.footer-cyber {
    background: linear-gradient(180deg, #0a0a0f, #0a1425);
    border-top: 2px solid var(--fusion-cyan);
}

/* =========================================================
   NUEVO ESTILO CLARO — FUSION PRINCIPAL
   (Pegar al FINAL de usuarios.css)
========================================================= */

:root {
    --fusion-azul: #0a3d62;
    --fusion-cyan: #00eaff;
    --fusion-celeste: #e9f6ff;
    --fusion-blanco: #ffffff;
    --fusion-gris: #f2f5f8;
    --fusion-borde: rgba(10, 61, 98, 0.25);
}

/* ======= FONDO GENERAL (CLARO) ======= */
body {
    background: linear-gradient(180deg, #ffffff, #e9f6ff);
    color: #0a1f2f;
}

/* ======= TARJETAS CLARAS (ESTILO FUSION) ======= */
.card-cyber,
.glass-card,
.container-cyberpunk,
.cyber-form,
.cyber-form-dark {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(10px);
    border: 1px solid var(--fusion-borde);
    box-shadow:
        0 10px 25px rgba(10, 61, 98, 0.08),
        inset 0 0 10px rgba(255, 255, 255, 0.6);
    border-radius: 18px;
}

/* ======= TÍTULOS AL ESTILO FUSION ======= */
.neon-title-cyberpunk,
.glass-card h1,
.cyber-form h1 {
    color: var(--fusion-azul);
    text-shadow: none;
    font-weight: 700;
}

/* Subtítulos suaves */
.neon-subtitle-soft,
.glass-card h5 {
    color: #0a3d62;
    opacity: 0.85;
}

/* ======= FORMULARIOS CLAROS ======= */
.cyber-form .form-control,
.cyber-form-dark .form-control,
.cyber-form .form-select,
.cyber-form-dark .form-select {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.15);
    color: #111;
    border-radius: 12px;
    padding: 12px 15px;
    transition: all 0.3s ease;
}

/* Focus estilo FITZONE */
.cyber-form .form-control:focus,
.cyber-form-dark .form-control:focus,
.cyber-form .form-select:focus,
.cyber-form-dark .form-select:focus {
    background: #ffffff;
    border-color: #00ff9c;
    box-shadow: 0 0 0 4px rgba(255, 106, 0, 0.15);
    outline: none;
}

/* Labels más profesionales */
.cyber-form label,
.cyber-form-dark label {
    color: var(--fusion-azul);
    font-weight: 600;
}

/* ======= BOTONES FUSION CLAROS ======= */
.btn-cyber,
.cyber-form .btn-primary,
.cyber-form-dark .btn-primary {
    background: var(--fusion-azul);
    border: none;
    color: white;
    border-radius: 12px;
    transition: 0.25s ease;
}

.btn-cyber:hover,
.cyber-form .btn-primary:hover,
.cyber-form-dark .btn-primary:hover {
    background: #0b4b78;
    box-shadow: 0 0 12px rgba(10, 61, 98, 0.3);
}

/* Botón "Volver" estilo Fusion */
.cyber-form .btn-success,
.cyber-form-dark .btn-success {
    background: #00c39a;
    border: none;
    color: white;
}

.cyber-form .btn-success:hover,
.cyber-form-dark .btn-success:hover {
    background: #00a882;
}

/* ======= NAVBAR MÁS CLARA ======= */
.navbar-cyberpunk {
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(8px);
    border-bottom: 2px solid var(--fusion-cyan);
}

.navbar-cyberpunk .nav-link {
    color: var(--fusion-azul) !important;
}

.navbar-cyberpunk .nav-link:hover,
.navbar-cyberpunk .nav-link.active {
    color: var(--fusion-cyan) !important;
}

/* ======= TABLAS MÁS CLARAS ======= */
table.dataTable {
    background-color: white !important;
    color: #0a1f2f !important;
}

table.dataTable thead {
    background: #00eaff !important;
    color: white !important;
}

table.dataTable tbody tr {
    background-color: #ffffff !important;
}

table.dataTable tbody tr:nth-child(even) {
    background-color: #f2f6ff !important;
}

.socio-inactivo {
    opacity: 0.5;
}

.socio-inactivo td {
    color: #999;
}

.contador-card {
    border-radius: 15px;
    padding: 10px;
    transition: all 0.25s ease;
}

.contador-card:hover {
    transform: translateY(-6px) scale(1.03);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.4);
}


.total-card {
    background: linear-gradient(135deg, #000000, #1f1f1f);
}

.icono-card {
    font-size: 3.5rem;
    opacity: 0.8;
    transition: transform 0.3s ease;
}

.contador-card:hover .icono-card {
    transform: scale(1.2) rotate(5deg);
}

/* ======= FOOTER (MANTIENE IDENTIDAD FUSION) ======= */
.footer-cyber {
    background: linear-gradient(180deg, #0a3d62, #0b1f2f);
    color: white;
}

/* ================================
   PERFIL USUARIO — Avatar moderno
================================ */

/* ================================
   SIDEBAR MODERNO — BLANCO
================================ */

.sidebar {
    position: fixed;
    left: 0;
    top: 0;
    width: 250px;
    height: 100vh;
    padding: 20px 0;
    transform: translateX(-100%);
    background: #ffffff;    /* <-- BLANCO */
    border-right: 1px solid #eee;
    z-index: 9999;
    box-shadow: 5px 0 20px rgba(0, 0, 0, 0.12);
    display: flex;
    flex-direction: column;
    justify-content: space-between;        /* 🔥 clave */
    transition: width 0.3s ease;
}

.sidebar.open {
    transform: translateX(0);
}

.sidebar.collapsed {
    width: 80px;
}

.sidebar-content {
    overflow-y: auto;
}

/* ===== PERFIL ===== */
.sidebar-profile {
    width: 100%;
    text-align: center;
    padding: 20px;
    border-bottom: 1px solid #e5e7eb;    /* línea muy sutil */
}

.sidebar-avatar {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 50%;
    border: 3px solid #ff6a00;
}

.sidebar-username {
    margin-top: 10px;
    color: #0a3d62;
    font-weight: 600;
}

.sidebar-role {
    font-size: 12px;
    color: #555;
}


/* ================================
   SIDEBAR - ESTILO PANEL PROFESIONAL
================================ */
/* PERFIL */
.sidebar-profile {
    background: #f8fafc;
    text-align: center;
    padding: 20px;
}

/* QUITA LÍNEAS Y VIÑETAS */
.sidebar-menu li {
    list-style: none;
    border: none;
}

/* LINKS ESTILO PANEL */
.sidebar-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    color: #0a3d62;
    text-decoration: none;
    border-radius: 10px;
    margin-bottom: 6px;
    transition: all 0.2s ease;
    position: relative;
    font-weight: 500;
}

/* EFECTO HOVER PROFESIONAL */
.sidebar-link:hover {
    background: #e5f1ff;
    transform: translateX(4px);
    color: #111;
}

.link-content {
    display: flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
}

/* ÍCONOS */
.sidebar-link i {
    font-size: 18px;
    min-width: 20px;        /* 🔥 evita que se encimen */
    text-align: center;
    color: #999;
    transition: 0.3s;
}

.sidebar-link:hover i {
    color: #ff6a00;
}

.sidebar-link.active {
    color: #ff6a00;
    font-weight: 600;
}

.sidebar-link.active i {
    color: #ff6a00;
}

.sidebar-link.active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 4px;
    background: #ff6a00;
    border-radius: 4px;
}

.sidebar-submenu {
    list-style: none;
    padding-left: 40px;
    /* 🔥 más indentación */
    margin-top: 5px;
    border-left: 2px solid rgba(255, 106, 0, 0.2);
    /* línea guía */
    background: rgba(0, 0, 0, 0.02);
    border-radius: 6px;
    padding: 10px 0 10px 40px;
}

.sidebar-sublink {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    font-size: 0.9rem;
    color: #777;
    text-decoration: none;
    transition: all 0.3s ease;
}

.sidebar-sublink:hover {
    color: #ff6a00;
    transform: translateX(3px);
}

.sidebar-sublink i {
    font-size: 0.95rem;
    color: #999;
    transition: 0.3s;
}

.sidebar-sublink:hover i,
.sidebar-sublink.active i {
    color: #ff6a00;
}

.chevron {
    transition: transform 0.3s ease;
}

.rotate {
    transform: rotate(180deg);
}

.btn-collapse {
    width: 100%;
    background: none;
    border: none;
    padding: 10px;
    cursor: pointer;
    color: #888;
    transition: 0.3s;
}

.btn-collapse:hover {
    color: #ff6a00;
}

.slide-enter-active,
.slide-leave-active {
    transition: all 0.3s ease;
    overflow: hidden;
}

.slide-enter-from,
.slide-leave-to {
    max-height: 0;
    opacity: 0;
}

.slide-enter-to,
.slide-leave-from {
    max-height: 200px;
    opacity: 1;
}


/* FOOTER (LOGOUT ABAJO) */
.sidebar-footer {
    padding: 15px;
    border-top: 1px solid #e5e7eb;
}

/* BOTÓN LOGOUT ESTILO PANEL */
.btn-logout {
    width: 100%;
    padding: 10px;
    background: #e63946;
    color: white;
    border: none;
    border-radius: 12px;
    font-weight: 600;
    box-shadow: 0 4px 10px rgba(230, 57, 70, 0.25);
}

.btn-logout:hover {
    background: #c71f2e;
    transform: translateY(-1px);
}


/* --- CABECERA DEL PANEL (TÍTULO) --- */
.sidebar-header {
    padding: 20px;
    margin-top: 60px;    /* deja espacio para la hamburguesa */
    text-align: center;
    border-bottom: 1px solid #e5e7eb;
    background: #0a3d62;
    color: white;
}

.sidebar-header h5 {
    margin: 0;
    font-weight: 700;
}

.sidebar-header small {
    opacity: 0.8;
}

.sidebar-title {
    font-size: 18px;
    font-weight: 700;
    color: #0b3b60;    /* Azul profesional */
    margin: 0;
}

/* Layout para paginas con DataTable: mantiene el footer al fondo
   cuando la tabla tiene pocas filas y lo empuja si la tabla crece. */
body.datatable-page #app,
body.global-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.datatable-page .main-content,
body.global-page .main-content {
    flex: 1 0 auto;
}

body.datatable-page .footer-cyber,
body.global-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

/* ================================
   ASISTENCIA POR QR
================================ */
body.asistencia-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.asistencia-page .main-content {
    flex: 1 0 auto;
}

body.asistencia-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

body.asistencia-inactivos-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.asistencia-inactivos-page .main-content {
    flex: 1 0 auto;
}

body.asistencia-inactivos-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

body.confirmacion-pagos-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.confirmacion-pagos-page .main-content {
    flex: 1 0 auto;
}

body.confirmacion-pagos-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.asistencia-panel {
    max-width: 1120px;
    margin: 0 auto;
}

.asistencia-status {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    margin-bottom: 24px;
    border-radius: 14px;
    border: 1px solid rgba(10, 61, 98, 0.16);
    background: #ffffff;
    color: #0a1f2f;
}

.asistencia-status i {
    font-size: 1.8rem;
}

.asistencia-status p {
    margin: 0;
}

.asistencia-status.is-pending i,
.asistencia-status.is-checking i {
    color: #0a3d62;
}

.asistencia-status.is-inside {
    border-color: rgba(25, 135, 84, 0.35);
    background: #edf8f2;
}

.asistencia-status.is-inside i {
    color: #198754;
}

.asistencia-status.is-outside {
    border-color: rgba(220, 53, 69, 0.35);
    background: #fff1f2;
}

.asistencia-status.is-outside i {
    color: #dc3545;
}

.qr-grid {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 420px);
    gap: 24px;
    align-items: stretch;
}

.qr-card,
.asistencia-card {
    position: relative;
    min-height: 420px;
    padding: 20px;
    border: 1px solid rgba(10, 61, 98, 0.16);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.08);
}

.qr-reader {
    width: 100%;
    min-height: 360px;
    overflow: hidden;
    border-radius: 12px;
    background: #0a1f2f;
}

.qr-blocker {
    position: absolute;
    inset: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 24px;
    border-radius: 12px;
    background: rgba(10, 31, 47, 0.92);
    color: #ffffff;
    text-align: center;
}

.qr-blocker i {
    font-size: 3rem;
    color: #00eaff;
}

.asistencia-card h2 {
    color: #0a3d62;
    font-size: 1.35rem;
    margin-bottom: 18px;
}

.asistencia-card dl {
    display: grid;
    gap: 12px;
    margin-bottom: 22px;
}

.asistencia-card dl div {
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(10, 61, 98, 0.12);
}

.asistencia-card dt {
    color: #0a3d62;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.asistencia-card dd {
    margin: 0;
    color: #0a1f2f;
    overflow-wrap: anywhere;
}

@media (max-width: 991px) {
    .qr-grid {
        grid-template-columns: 1fr;
    }
}

/* ================================
   QR DEL GIMNASIO
================================ */
body.qr-gym-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.qr-gym-page .main-content {
    flex: 1 0 auto;
}

body.qr-gym-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.qr-gym-panel {
    max-width: 1120px;
    margin: 0 auto;
}

.qr-gym-grid {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(280px, 420px);
    gap: 24px;
    align-items: stretch;
}

.qr-display-card,
.qr-settings-card {
    padding: 22px;
    border: 1px solid rgba(10, 61, 98, 0.16);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.08);
}

.qr-print-sheet {
    min-height: 560px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 28px;
    border: 2px dashed rgba(10, 61, 98, 0.2);
    border-radius: 16px;
    background: #ffffff;
    color: #0a1f2f;
    text-align: center;
}

.qr-gym-logo {
    max-width: 240px;
    max-height: 90px;
    object-fit: contain;
}

.qr-print-sheet h2 {
    color: #0a3d62;
    font-size: 1.6rem;
    margin: 0;
}

.qr-gym-container {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 312px;
    height: 312px;
    padding: 16px;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.14);
}

.qr-gym-container img,
.qr-gym-container canvas {
    width: 280px;
    height: 280px;
}

.qr-settings-card h2 {
    color: #0a3d62;
    font-size: 1.35rem;
    margin-bottom: 18px;
}

.qr-payload-preview {
    padding: 14px;
    border-radius: 12px;
    background: #f2f6ff;
    border: 1px solid rgba(10, 61, 98, 0.12);
}

.qr-payload-preview pre {
    margin: 10px 0 0;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    color: #0a1f2f;
}

@media (max-width: 991px) {
    .qr-gym-grid {
        grid-template-columns: 1fr;
    }
}

@media print {
    body.qr-gym-page {
        padding-top: 0;
        background: #ffffff !important;
    }

    body.qr-gym-page #header,
    body.qr-gym-page .sidebar,
    body.qr-gym-page .btn-sidebar-toggle,
    body.qr-gym-page .qr-settings-card,
    body.qr-gym-page .footer-cyber {
        display: none !important;
    }

    body.qr-gym-page .main-content {
        margin-left: 0;
        padding: 0;
    }

    body.qr-gym-page .container-cyberpunk,
    body.qr-gym-page .qr-display-card {
        border: none;
        box-shadow: none;
        background: #ffffff;
    }

    .qr-gym-grid {
        display: block;
    }

    .qr-print-sheet {
        min-height: 100vh;
        border: none;
    }
}

/* ================================
   ASISTENCIA PRESENCIAL ADMIN
================================ */
body.asistencia-presencial-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.asistencia-presencial-page .main-content {
    flex: 1 0 auto;
}

body.asistencia-presencial-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.asistencia-presencial-panel {
    max-width: 1180px;
    margin: 0 auto;
}

.presencial-grid {
    display: grid;
    grid-template-columns: minmax(300px, 1fr) minmax(320px, 440px);
    gap: 24px;
    align-items: stretch;
}

.presencial-search-card,
.presencial-detail-card {
    padding: 22px;
    border: 1px solid rgba(10, 61, 98, 0.16);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.08);
}

.presencial-search-card h2,
.presencial-detail-card h2 {
    color: #0a3d62;
    font-size: 1.35rem;
    margin-bottom: 18px;
}

.presencial-results {
    display: grid;
    gap: 10px;
    max-height: 560px;
    overflow-y: auto;
    padding-right: 4px;
}

.presencial-result {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    width: 100%;
    padding: 14px;
    border: 1px solid rgba(10, 61, 98, 0.12);
    border-radius: 12px;
    background: #ffffff;
    color: #0a1f2f;
    text-align: left;
    transition: 0.2s ease;
}

.presencial-result:hover,
.presencial-result.selected {
    border-color: #00eaff;
    box-shadow: 0 8px 18px rgba(10, 61, 98, 0.12);
    transform: translateY(-1px);
}

.presencial-result small {
    display: block;
    color: #607080;
    margin-top: 2px;
}

.empty-results,
.empty-selection {
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    border: 1px dashed rgba(10, 61, 98, 0.2);
    border-radius: 14px;
    color: #607080;
    text-align: center;
}

.empty-selection {
    flex-direction: column;
    gap: 12px;
}

.empty-selection i {
    font-size: 3rem;
    color: #0a3d62;
}

.selected-member {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    margin-bottom: 18px;
    border-radius: 14px;
    background: #f2f6ff;
    border: 1px solid rgba(10, 61, 98, 0.12);
}

.selected-member h3 {
    color: #0a3d62;
    font-size: 1.3rem;
    margin: 4px 0;
}

.selected-member p {
    margin: 0;
}

.member-number {
    color: #607080;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.member-data {
    display: grid;
    gap: 10px;
    margin-bottom: 18px;
}

.member-data div {
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(10, 61, 98, 0.12);
}

.member-data dt {
    color: #0a3d62;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.member-data dd {
    margin: 0;
    overflow-wrap: anywhere;
}

@media (max-width: 991px) {
    .presencial-grid {
        grid-template-columns: 1fr;
    }
}

/* ================================
   ALMANAQUE ASISTENCIA SOCIO
================================ */
body.asistencia-mensual-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.asistencia-mensual-page .main-content {
    flex: 1 0 auto;
}

body.asistencia-mensual-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

body.pago-membresias-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.pago-membresias-page .main-content {
    flex: 1 0 auto;
}

body.pago-membresias-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.asistencia-mensual-panel {
    max-width: 1120px;
    margin: 0 auto;
}

.calendar-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px;
    border: 1px solid rgba(10, 61, 98, 0.14);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.92);
    color: #0a1f2f;
}

.calendar-toolbar h2 {
    margin: 0;
    color: #0a3d62;
    text-transform: capitalize;
    text-align: center;
}

.calendar-toolbar p {
    margin: 4px 0 0;
    text-align: center;
    color: #607080;
}

.attendance-summary {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin: 18px 0;
}

.attendance-summary div {
    padding: 18px;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 8px 18px rgba(10, 61, 98, 0.08);
    text-align: center;
}

.attendance-summary span {
    display: block;
    color: #0a3d62;
    font-size: 2rem;
    font-weight: 800;
}

.attendance-summary small {
    color: #607080;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.calendar-weekdays,
.attendance-calendar {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 10px;
}

.calendar-weekdays {
    margin-bottom: 10px;
}

.calendar-weekdays span {
    padding: 10px;
    border-radius: 10px;
    background: #0a3d62;
    color: #ffffff;
    text-align: center;
    font-weight: 700;
}

.calendar-day {
    min-height: 118px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 10px;
    padding: 12px;
    border: 1px solid rgba(10, 61, 98, 0.12);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.94);
    color: #0a1f2f;
    box-shadow: 0 8px 18px rgba(10, 61, 98, 0.05);
}

.calendar-day.is-empty {
    background: transparent;
    border-style: dashed;
    box-shadow: none;
}

.calendar-day.is-today {
    border-color: #00eaff;
    box-shadow: 0 0 0 3px rgba(0, 234, 255, 0.16);
}

.calendar-day.has-attendance {
    background: linear-gradient(135deg, #0bbf72, #00e0a4);
    border-color: rgba(11, 191, 114, 0.7);
    color: #ffffff;
    box-shadow:
        0 12px 24px rgba(11, 191, 114, 0.28),
        inset 0 0 18px rgba(255, 255, 255, 0.18);
}

.day-number {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #f2f6ff;
    color: #0a3d62;
    font-weight: 800;
}

.calendar-day.has-attendance .day-number {
    background: rgba(255, 255, 255, 0.95);
    color: #08764a;
}

.attendance-mark {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: flex-end;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.95);
    color: #0aa466;
    font-size: 1.3rem;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.16);
}

.calendar-legend {
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
    margin-top: 16px;
    color: #0a1f2f;
}

.legend-dot {
    width: 12px;
    height: 12px;
    display: inline-block;
    border-radius: 50%;
    margin-right: 6px;
}

.legend-dot.attended {
    background: #198754;
}

.legend-dot.today {
    background: #00eaff;
}

@media (max-width: 767px) {
    .attendance-summary {
        grid-template-columns: 1fr;
    }

    .calendar-weekdays,
    .attendance-calendar {
        gap: 6px;
    }

    .calendar-weekdays span {
        padding: 8px 2px;
        font-size: 0.78rem;
    }

    .calendar-day {
        min-height: 78px;
        padding: 8px;
    }

    .attendance-mark {
        font-size: 0;
    }

    .attendance-mark i {
        font-size: 1rem;
    }
}

/* ================================
   ENTRENAMIENTOS ADMIN
================================ */
.training-admin-page {
    background:
        linear-gradient(135deg, rgba(255, 247, 237, 0.96), rgba(229, 249, 255, 0.96)),
        #f7fbff;
}

.training-admin-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.fusion-tabs {
    gap: 10px;
}

.fusion-tabs .nav-link {
    border: 1px solid rgba(10, 61, 98, 0.14);
    color: #0a3d62;
    background: #ffffff;
    font-weight: 800;
    box-shadow: 0 8px 20px rgba(10, 61, 98, 0.08);
}

.fusion-tabs .nav-link.active {
    color: #ffffff;
    background: linear-gradient(135deg, #ff7a18, #ff3d71);
    border-color: transparent;
    font-weight: 800;
}

.fusion-tabs .nav-item:nth-child(2) .nav-link.active {
    background: linear-gradient(135deg, #05b88f, #00a6d6);
}

.training-admin-card {
    border: 0;
    border-radius: 18px;
    color: #17202a;
    overflow: hidden;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.14);
}

.training-admin-card h3,
.training-admin-card h4,
.training-admin-card .form-label,
.training-admin-card .form-check-label {
    color: #102a43;
}

.workout-admin-card {
    background: linear-gradient(180deg, #fff7ed, #ffffff);
    border-top: 8px solid #ff7a18;
}

.exercise-admin-card {
    background: linear-gradient(180deg, #ecfdf5, #ffffff);
    border-top: 8px solid #05b88f;
}

.training-admin-page .form-control,
.training-admin-page .form-select {
    border-color: rgba(10, 61, 98, 0.18);
    background-color: #ffffff;
    color: #17202a;
}

.training-admin-page .form-control:focus,
.training-admin-page .form-select:focus {
    border-color: #00a6d6;
    box-shadow: 0 0 0 0.22rem rgba(0, 166, 214, 0.18);
}

.training-admin-preview {
    width: min(100%, 280px);
    height: 150px;
    object-fit: cover;
    border-radius: 14px;
    border: 3px solid #ffffff;
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.16);
}

.training-table-thumb {
    width: 74px;
    height: 48px;
    object-fit: cover;
    border-radius: 8px;
}

.exercise-video-preview {
    width: min(100%, 320px);
    aspect-ratio: 16 / 9;
    border-radius: 12px;
    background: #000000;
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.16);
}

.training-admin-page .table-wrapper-cyber {
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.1);
    box-shadow: 0 12px 28px rgba(10, 61, 98, 0.1);
}

.training-admin-page table.dataTable thead {
    background: #0a3d62;
}

.training-admin-page table.dataTable thead th {
    color: #ffffff;
    text-align: left;
}

.training-admin-page table.dataTable tbody td {
    text-align: left;
}

.exercise-admin-card table.dataTable thead {
    background: linear-gradient(135deg, #047857, #00a6d6);
}

.workout-admin-card table.dataTable thead {
    background: linear-gradient(135deg, #ff7a18, #ff3d71);
}

.training-admin-page .dataTables_wrapper,
.training-admin-page .dataTables_filter label,
.training-admin-page .dataTables_length label,
.training-admin-page .dataTables_info {
    color: #102a43;
}

.training-admin-page .dataTables_filter input,
.training-admin-page .dataTables_length select {
    background: #ffffff;
    color: #17202a;
    border-color: rgba(10, 61, 98, 0.24);
}

.training-day-card {
    padding: 18px;
    margin-bottom: 16px;
    border: 1px solid rgba(255, 122, 24, 0.2);
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 12px 24px rgba(255, 122, 24, 0.1);
}

.training-day-card .table {
    margin-bottom: 0;
}

.routine-table {
    --bs-table-bg: #fffaf3;
    --bs-table-striped-bg: #fff1df;
    --bs-table-color: #17202a;
    --bs-table-border-color: rgba(255, 122, 24, 0.18);
}

.routine-table thead {
    background: #ffe1bd;
    color: #7c2d12;
}

@media (max-width: 767px) {
    .training-admin-card {
        padding: 18px !important;
    }

    .fusion-tabs {
        display: grid;
        grid-template-columns: 1fr;
    }

    .fusion-tabs .nav-link {
        width: 100%;
    }
}

/* ================================
   FINANZAS
================================ */
.finance-expense-card {
    border: 1px solid rgba(220, 53, 69, 0.16);
    border-top: 8px solid #ff5a5f;
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(255, 245, 245, 0.98), rgba(235, 252, 255, 0.98)),
        #ffffff;
    color: #152536;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.12);
}

.finance-expense-card h3 {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #b4232f;
    font-weight: 900;
}

.finance-expense-card .form-label {
    color: #0a3d62;
    font-weight: 700;
}

.finance-expense-card .form-control,
.finance-expense-card .form-select {
    background: #ffffff;
    color: #17202a;
    border-color: rgba(10, 61, 98, 0.2);
}

.finance-expense-card .form-control:focus,
.finance-expense-card .form-select:focus {
    border-color: #00a6d6;
    box-shadow: 0 0 0 0.22rem rgba(0, 166, 214, 0.18);
}

.finance-income-card {
    border-color: rgba(25, 135, 84, 0.18);
    border-top-color: #20c997;
    background:
        linear-gradient(135deg, rgba(235, 255, 248, 0.98), rgba(238, 247, 255, 0.98)),
        #ffffff;
}

.finance-income-card h3 {
    color: #087f5b;
}

.finance-outcome-card {
    border-color: rgba(220, 53, 69, 0.16);
    border-top-color: #ff5a5f;
}

.finance-outcome-card h3 {
    color: #b4232f;
}

.finance-tabs .nav-link.active {
    background: linear-gradient(135deg, #20c997, #087f5b);
}

.finance-tabs .nav-item:nth-child(2) .nav-link.active {
    background: linear-gradient(135deg, #ff5a5f, #b4232f);
}

.finance-tabs .nav-item:nth-child(3) .nav-link.active {
    background: linear-gradient(135deg, #00a6d6, #5f3dc4);
}

.finance-tabs .nav-item:nth-child(4) .nav-link.active {
    background: linear-gradient(135deg, #f59f00, #0b7285);
}

.finance-category-card {
    border-color: rgba(95, 61, 196, 0.18);
    border-top-color: #5f3dc4;
    background:
        linear-gradient(135deg, rgba(238, 247, 255, 0.98), rgba(246, 240, 255, 0.98)),
        #ffffff;
}

.finance-category-card h3 {
    color: #4c2bb8;
}

.finance-close-card {
    border-color: rgba(245, 159, 0, 0.24);
    border-top-color: #f59f00;
    background:
        linear-gradient(135deg, rgba(255, 249, 219, 0.98), rgba(231, 245, 255, 0.98)),
        #ffffff;
}

.finance-close-card h3 {
    color: #0b7285;
}

.finance-chart-panel {
    position: relative;
    min-height: 340px;
    padding: 18px;
    border: 1px solid rgba(11, 114, 133, 0.16);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.finance-chart-panel canvas {
    width: 100% !important;
    height: 320px !important;
}

.finance-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 16px;
}

.finance-filter-btn {
    min-height: 40px;
    padding: 8px 18px;
    border: 1px solid rgba(10, 61, 98, 0.16);
    border-radius: 999px;
    color: #0a3d62;
    background: #ffffff;
    font-weight: 800;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.finance-filter-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(10, 61, 98, 0.12);
}

.finance-filter-btn.active {
    color: #ffffff;
    background: #0a3d62;
}

.finance-filter-income.active {
    background: #087f5b;
}

.finance-filter-outcome.active {
    background: #b4232f;
}

/* ================================
   EJERCICIOS USUARIO
================================ */
body.ejercicios-user-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.ejercicios-user-page .main-content {
    flex: 1 0 auto;
}

body.ejercicios-user-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.ejercicios-user-panel {
    max-width: 1180px;
    margin: 0 auto;
}

.exercise-catalog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 22px;
}

.exercise-catalog-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 0;
    border-radius: 18px;
    background: linear-gradient(180deg, #ecfdf5, #ffffff);
    border: 1px solid rgba(5, 184, 143, 0.18);
    box-shadow: 0 14px 30px rgba(10, 61, 98, 0.1);
    color: #17202a;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    overflow: hidden;
}

.exercise-catalog-card:hover {
    transform: translateY(-8px);
    border-color: rgba(5, 184, 143, 0.45);
    box-shadow: 0 22px 42px rgba(10, 61, 98, 0.18);
}

.exercise-catalog-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 22px 12px;
}

.exercise-catalog-image {
    width: 100%;
    height: 190px;
    object-fit: cover;
    background: #eef6fb;
}

.exercise-catalog-header i {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, #05b88f, #00a6d6);
    color: #ffffff;
    font-size: 1.35rem;
}

.exercise-catalog-header h2 {
    margin: 0;
    color: #0a3d62;
    font-size: 1.25rem;
    font-weight: 900;
}

.exercise-catalog-description {
    padding: 0 22px;
    color: #35485c;
    line-height: 1.6;
}

.exercise-no-video {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: auto;
    margin-left: 22px;
    margin-right: 22px;
    margin-bottom: 22px;
    padding: 12px;
    border-radius: 12px;
    background: #eef6fb;
    color: #607080;
    font-weight: 700;
}

.exercise-catalog-card .btn-training-detail {
    margin: auto 22px 22px;
}

.btn-training-detail {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 18px;
    border: 0;
    border-radius: 10px;
    color: #ffffff !important;
    font-weight: 900;
    background: linear-gradient(135deg, #00a6d6, #2abf88);
    box-shadow: 0 10px 22px rgba(0, 166, 214, 0.22);
}

.btn-training-detail:hover {
    color: #ffffff !important;
    transform: translateY(-2px);
    box-shadow: 0 14px 26px rgba(0, 166, 214, 0.3);
}

.empty-exercises {
    display: grid;
    place-items: center;
    gap: 10px;
    padding: 44px 20px;
    border-radius: 18px;
    background: #ffffff;
    color: #607080;
    box-shadow: 0 12px 24px rgba(10, 61, 98, 0.08);
}

.empty-exercises i {
    font-size: 2.5rem;
    color: #00a6d6;
}

.exercise-video-modal {
    border: 0;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(10, 61, 98, 0.28);
}

.exercise-video-modal .modal-header {
    background: linear-gradient(135deg, #05b88f, #00a6d6);
    color: #ffffff;
}

.exercise-video-modal .modal-title {
    font-weight: 900;
}

.exercise-video-modal .btn-close {
    filter: invert(1);
}

.exercise-video-modal .modal-body {
    padding: 0;
    background: #000000;
}

.exercise-video-modal video {
    width: 100%;
    max-height: 76vh;
    display: block;
    background: #000000;
    border: 0;
}

.exercise-video-modal iframe {
    width: 100%;
    min-height: min(68vh, 620px);
    display: block;
    background: #000000;
    border: 0;
}

/* ================================
   RECETAS ADMIN
================================ */
.nutrition-admin-page {
    background:
        linear-gradient(135deg, rgba(240, 253, 244, 0.98), rgba(236, 253, 245, 0.98)),
        #ffffff;
}

.nutrition-admin-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(25, 135, 84, 0.14);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.nutrition-admin-card {
    border: 0;
    border-top: 8px solid #38b000;
    border-radius: 18px;
    background: linear-gradient(180deg, #f0fdf4, #ffffff);
    color: #17202a;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.12);
}

.nutrition-admin-card h3,
.nutrition-admin-card .form-label,
.nutrition-admin-card .form-check-label {
    color: #0f5132;
}

.nutrition-admin-page .table-wrapper-cyber {
    background: #ffffff;
    border: 1px solid rgba(25, 135, 84, 0.12);
    box-shadow: 0 12px 28px rgba(10, 61, 98, 0.1);
}

.nutrition-admin-page table.dataTable thead {
    background: linear-gradient(135deg, #087f5b, #38b000);
}

.nutrition-admin-page table.dataTable thead th,
.nutrition-admin-page table.dataTable tbody td {
    text-align: left;
}

.nutrition-admin-page table.dataTable thead th {
    color: #ffffff;
}

/* ================================
   HISTORIAS ADMIN / SOCIO
================================ */
.stories-admin-page,
.story-user-page {
    background:
        linear-gradient(135deg, rgba(255, 247, 237, 0.96), rgba(239, 246, 255, 0.96)),
        #ffffff;
}

.stories-admin-page .container-cyberpunk,
.story-user-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(255, 122, 24, 0.16);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.story-admin-card,
.story-submit-card {
    border: 0;
    border-top: 8px solid #ff7a18;
    border-radius: 18px;
    background: linear-gradient(180deg, #fff7ed, #ffffff);
    color: #17202a;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.12);
}

.story-submit-card {
    padding: 24px;
}

.story-admin-card h3,
.story-admin-card .form-label,
.story-admin-card .form-check-label,
.story-submit-card .form-label {
    color: #7c2d12;
    font-weight: 700;
}

.stories-admin-page .form-control,
.stories-admin-page .form-select,
.story-user-page .form-control {
    background: #ffffff;
    color: #17202a;
    border-color: rgba(10, 61, 98, 0.2);
}

.stories-admin-page .form-control:focus,
.stories-admin-page .form-select:focus,
.story-user-page .form-control:focus {
    border-color: #ff7a18;
    box-shadow: 0 0 0 0.22rem rgba(255, 122, 24, 0.18);
}

.stories-admin-page .table-wrapper-cyber {
    background: #ffffff;
    border: 1px solid rgba(255, 122, 24, 0.12);
    box-shadow: 0 12px 28px rgba(10, 61, 98, 0.1);
}

.stories-admin-page table.dataTable thead {
    background: linear-gradient(135deg, #ff7a18, #0a3d62);
}

.stories-admin-page table.dataTable thead th,
.stories-admin-page table.dataTable tbody td {
    text-align: left;
}

.stories-admin-page table.dataTable thead th {
    color: #ffffff;
}

.story-user-panel {
    max-width: 980px;
    margin: 0 auto;
}

.story-submit-preview {
    width: min(100%, 360px);
    height: 220px;
    object-fit: cover;
    border-radius: 14px;
    border: 3px solid #ffffff;
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.16);
}

body.story-user-page #app,
body.stories-admin-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.story-user-page .main-content,
body.stories-admin-page .main-content {
    flex: 1 0 auto;
}

body.story-user-page .footer-cyber,
body.stories-admin-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

/* ================================
   WHATSAPP ADMIN
================================ */
.whatsapp-admin-page {
    background:
        linear-gradient(135deg, rgba(236, 253, 245, 0.97), rgba(239, 246, 255, 0.97)),
        #ffffff;
}

.whatsapp-admin-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(37, 211, 102, 0.18);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.whatsapp-admin-panel {
    max-width: 1120px;
    margin: 0 auto;
}

.whatsapp-config-card {
    padding: 24px;
    border: 0;
    border-top: 8px solid #25d366;
    border-radius: 18px;
    background: linear-gradient(180deg, #ecfdf5, #ffffff);
    color: #17202a;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.12);
}

.whatsapp-config-card .form-label,
.whatsapp-config-card .form-check-label {
    color: #075e54;
    font-weight: 700;
}

.whatsapp-admin-page .form-control,
.whatsapp-admin-page .form-select {
    background: #ffffff;
    color: #17202a;
    border-color: rgba(10, 61, 98, 0.2);
}

.whatsapp-admin-page .form-control:focus,
.whatsapp-admin-page .form-select:focus {
    border-color: #25d366;
    box-shadow: 0 0 0 0.22rem rgba(37, 211, 102, 0.18);
}

.whatsapp-admin-page .table-wrapper-cyber {
    background: #ffffff;
    border: 1px solid rgba(37, 211, 102, 0.12);
    box-shadow: 0 12px 28px rgba(10, 61, 98, 0.1);
}

.whatsapp-admin-page table thead {
    background: linear-gradient(135deg, #075e54, #25d366);
    color: #ffffff;
}

.whatsapp-admin-page table td {
    text-align: left;
    vertical-align: middle;
}

body.whatsapp-admin-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.whatsapp-admin-page .main-content {
    flex: 1 0 auto;
}

body.whatsapp-admin-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

/* ================================
   COMUNIDADES
================================ */
.communities-page,
.community-detail-page,
.communities-admin-page {
    background:
        linear-gradient(135deg, rgba(239, 246, 255, 0.97), rgba(236, 253, 245, 0.96)),
        #ffffff;
}

.communities-page .container-cyberpunk,
.community-detail-page .container-cyberpunk,
.communities-admin-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(0, 166, 214, 0.16);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.communities-panel {
    max-width: 1180px;
    margin: 0 auto;
}

.community-create-card,
.community-invites,
.community-post-form,
.community-side-card,
.community-admin-detail {
    padding: 22px;
    border: 1px solid rgba(10, 61, 98, 0.12);
    border-radius: 18px;
    background: linear-gradient(180deg, #eff6ff, #ffffff);
    color: #17202a;
    box-shadow: 0 14px 30px rgba(10, 61, 98, 0.1);
}

.community-create-card {
    border-top: 8px solid #00a6d6;
}

.community-create-card h2,
.community-invites h2,
.community-post-form h2,
.community-side-card h2,
.community-side-card h3,
.community-admin-detail h2 {
    color: #0a3d62;
    font-weight: 900;
}

.community-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 22px;
}

.community-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(0, 166, 214, 0.16);
    box-shadow: 0 14px 30px rgba(10, 61, 98, 0.1);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.community-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 22px 42px rgba(10, 61, 98, 0.18);
}

.community-card img {
    width: 100%;
    height: 190px;
    object-fit: cover;
    background: #eef6fb;
}

.community-card-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 10px;
    padding: 20px;
}

.community-card-head,
.community-invite-row,
.community-member-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.community-card h2 {
    color: #0a3d62;
    font-size: 1.35rem;
    font-weight: 900;
    margin: 0;
}

.community-card p {
    color: #35485c;
    line-height: 1.55;
}

.community-card small,
.community-member-row small,
.community-hero small {
    display: block;
    color: #607080;
}

.community-actions {
    margin-top: auto;
}

.community-invite-row,
.community-member-row {
    padding: 12px;
    margin-top: 10px;
    border-radius: 12px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.1);
}

.community-hero {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 24px;
    align-items: center;
    margin-bottom: 24px;
    padding: 22px;
    border-radius: 20px;
    background: linear-gradient(135deg, #0a3d62, #00a6d6);
    color: #ffffff;
    box-shadow: 0 18px 36px rgba(10, 61, 98, 0.2);
}

.community-hero img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 16px;
    border: 4px solid rgba(255, 255, 255, 0.35);
}

.community-hero h1 {
    margin: 10px 0;
    font-weight: 900;
}

.community-hero p,
.community-hero small {
    color: rgba(255, 255, 255, 0.86);
}

.community-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 330px;
    gap: 24px;
    align-items: start;
}

.community-feed {
    display: grid;
    gap: 18px;
}

.community-post {
    padding: 20px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 12px 24px rgba(10, 61, 98, 0.08);
}

.community-post header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
    color: #0a3d62;
}

.community-post > img,
.admin-community-post img {
    width: 100%;
    max-height: 380px;
    object-fit: cover;
    border-radius: 14px;
    margin: 10px 0;
}

.community-comments {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid rgba(10, 61, 98, 0.12);
}

.community-comments h3 {
    color: #0a3d62;
    font-size: 1rem;
    font-weight: 900;
}

.community-comment {
    display: grid;
    gap: 2px;
    padding: 10px;
    margin-bottom: 8px;
    border-radius: 10px;
    background: #f2f6ff;
}

.community-comment-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
}

.community-side {
    display: grid;
    gap: 18px;
}

.communities-admin-page table.dataTable thead th,
.communities-admin-page table.dataTable tbody td {
    text-align: left;
}

.community-admin-actions {
    white-space: nowrap;
}

.community-admin-actions button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.communities-admin-page table.dataTable thead {
    background: linear-gradient(135deg, #0a3d62, #00a6d6);
}

.admin-community-post {
    padding: 14px;
    margin-bottom: 12px;
    border-radius: 14px;
    background: #f8fbff;
    border: 1px solid rgba(10, 61, 98, 0.1);
}

.admin-community-comments {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(10, 61, 98, 0.12);
}

.admin-community-comments h4 {
    margin: 0 0 10px;
    color: #0a3d62;
    font-size: 0.95rem;
    font-weight: 900;
}

.admin-community-comment {
    padding: 10px 12px;
    margin-bottom: 8px;
    border-radius: 10px;
    background: #eef5ff;
    border: 1px solid rgba(10, 61, 98, 0.08);
}

.admin-community-comment-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 4px;
}

.admin-community-comment-header small,
.admin-community-empty-comments {
    color: #5d7188;
    font-size: 0.84rem;
}

.admin-community-comment p {
    margin: 0;
}

body.communities-page #app,
body.community-detail-page #app,
body.communities-admin-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.communities-page .main-content,
body.community-detail-page .main-content,
body.communities-admin-page .main-content {
    flex: 1 0 auto;
}

body.communities-page .footer-cyber,
body.community-detail-page .footer-cyber,
body.communities-admin-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

/* Staff admin */
body.staff-admin-page {
    background: #edf6f8;
}

body.staff-admin-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.staff-admin-page .main-content {
    flex: 1 0 auto;
}

body.staff-admin-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

/* Clases particulares */
body.private-classes-admin-page,
body.private-classes-user-page {
    background: #eef7ff;
}

body.private-classes-admin-page #app,
body.private-classes-user-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.private-classes-admin-page .main-content,
body.private-classes-user-page .main-content {
    flex: 1 0 auto;
}

body.private-classes-admin-page .footer-cyber,
body.private-classes-user-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.private-classes-admin-page .container-cyberpunk,
.private-classes-user-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(0, 166, 214, 0.16);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.private-classes-admin-page .neon-title-cyberpunk,
.private-classes-user-page .neon-title-cyberpunk {
    color: #0a3d62;
    text-shadow: none;
}

.private-classes-admin-page .neon-subtitle-cyber,
.private-classes-user-page .neon-subtitle-cyber {
    color: #4b6378;
    text-shadow: none;
}

.private-class-admin-card {
    border: 0;
    border-left: 7px solid #00a6d6;
    border-radius: 18px;
    background: linear-gradient(135deg, #e8f8ff, #ffffff);
    color: #223242;
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.12);
}

.private-class-enrollment-card {
    border-left-color: #2abf88;
    background: linear-gradient(135deg, #ecfff8, #ffffff);
}

.private-class-enrollment-form {
    border-radius: 16px;
    background: #f4fbff;
    border: 1px solid rgba(0, 166, 214, 0.14);
}

.private-class-enrollment-form h4 {
    color: #0a3d62;
    font-weight: 900;
}

.private-class-admin-card h3,
.private-class-admin-card .form-label,
.private-class-admin-card .form-check-label {
    color: #0a3d62;
    font-weight: 800;
}

.private-classes-admin-page .form-control,
.private-classes-admin-page .form-select,
.private-classes-user-page .form-control,
.private-classes-user-page .form-select {
    color: #1f2f3f;
    background: #ffffff;
    border: 1px solid #b8cfda;
}

.private-classes-admin-page .form-control:focus,
.private-classes-admin-page .form-select:focus,
.private-classes-user-page .form-control:focus,
.private-classes-user-page .form-select:focus {
    border-color: #00a6d6;
    box-shadow: 0 0 0 0.2rem rgba(0, 166, 214, 0.16);
}

.private-class-primary-btn,
.private-class-subscribe-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 18px;
    border: 0;
    border-radius: 10px;
    color: #ffffff;
    font-weight: 900;
    background: linear-gradient(135deg, #00a6d6, #2abf88);
    box-shadow: 0 10px 22px rgba(0, 166, 214, 0.22);
}

.private-class-primary-btn:hover,
.private-class-subscribe-btn:hover {
    color: #ffffff;
    transform: translateY(-2px);
}

.private-class-subscribe-btn:disabled {
    color: #ffffff;
    background: linear-gradient(135deg, #5f7488, #8ba2b3);
    box-shadow: none;
    transform: none;
}

.private-class-table-wrapper {
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.1);
    overflow-x: auto;
}

.private-class-table-wrapper .dataTables_wrapper {
    width: 100%;
}

.private-classes-admin-page table.dataTable thead {
    background: linear-gradient(135deg, #0a3d62, #00a6d6);
}

.private-classes-admin-page table.dataTable thead th,
.private-classes-admin-page table.dataTable tbody td {
    text-align: left;
}

.private-classes-admin-page table.dataTable td:last-child {
    white-space: nowrap;
}

.private-classes-admin-page table.dataTable.dtr-inline.collapsed > tbody > tr > td.dtr-control::before,
.private-classes-admin-page table.dataTable.dtr-inline.collapsed > tbody > tr > th.dtr-control::before {
    background-color: #00a6d6;
    border: 0;
    box-shadow: 0 4px 10px rgba(0, 166, 214, 0.28);
}

.private-class-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 22px;
}

.private-class-user-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 22px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(0, 166, 214, 0.16);
    box-shadow: 0 14px 30px rgba(10, 61, 98, 0.1);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.private-class-user-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 22px 42px rgba(10, 61, 98, 0.18);
}

.private-class-user-head {
    display: flex;
    align-items: center;
    gap: 14px;
}

.private-class-icon {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 16px;
    background: linear-gradient(135deg, #00a6d6, #2abf88);
    color: #ffffff;
    font-size: 1.6rem;
}

.private-class-user-card h2 {
    margin: 0;
    color: #0a3d62;
    font-size: 1.28rem;
    font-weight: 900;
}

.private-class-user-card small,
.private-class-description {
    color: #526a7f;
}

.private-class-description {
    line-height: 1.55;
}

.private-class-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    border-radius: 14px;
    background: #eef8ff;
    color: #0a3d62;
}

.private-class-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
}

.private-class-meta strong {
    color: #087f5b;
    font-size: 1.15rem;
}

.private-class-pay-box {
    margin-top: auto;
}

.private-class-bank-card {
    border-radius: 18px;
    background: linear-gradient(135deg, #e7fbf5, #eef8ff);
    border: 1px solid rgba(42, 191, 136, 0.22);
    color: #0a3d62;
    box-shadow: 0 14px 30px rgba(10, 61, 98, 0.09);
}

.private-class-bank-card i {
    color: #087f5b;
}

.private-class-bank-card h3 {
    color: #0a3d62;
    font-weight: 900;
}

.private-class-bank-card p,
.private-class-bank-card small {
    color: #526a7f;
}

.private-class-bank-card small,
.private-class-bank-card strong {
    display: block;
}

.private-class-bank-card strong {
    color: #087f5b;
    font-size: 1.05rem;
    word-break: break-word;
}

.private-class-empty {
    display: grid;
    place-items: center;
    gap: 10px;
    padding: 44px 20px;
    border-radius: 18px;
    background: #ffffff;
    color: #607080;
    box-shadow: 0 12px 24px rgba(10, 61, 98, 0.08);
}

.private-class-empty i {
    font-size: 2.5rem;
    color: #00a6d6;
}

.fusion-comprobante-backdrop {
    position: fixed;
    inset: 0;
    z-index: 2500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(3, 14, 26, 0.72);
    backdrop-filter: blur(6px);
}

.fusion-comprobante-modal {
    width: min(980px, 96vw);
    max-height: 92vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(0, 166, 214, 0.2);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.32);
}

.fusion-comprobante-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    background: linear-gradient(135deg, #eef8ff, #e7fbf5);
    border-bottom: 1px solid rgba(10, 61, 98, 0.12);
}

.fusion-comprobante-header h3 {
    margin: 0;
    color: #0a3d62;
    font-size: 1.2rem;
    font-weight: 900;
}

.fusion-comprobante-header small {
    color: #526a7f;
    font-weight: 700;
}

.fusion-comprobante-body {
    min-height: 320px;
    max-height: calc(92vh - 86px);
    padding: 16px;
    overflow: auto;
    background: #f6fbff;
}

.fusion-comprobante-body img {
    display: block;
    max-width: 100%;
    max-height: calc(92vh - 120px);
    margin: 0 auto;
    border-radius: 12px;
    object-fit: contain;
    box-shadow: 0 12px 28px rgba(10, 61, 98, 0.16);
}

.fusion-comprobante-body iframe {
    width: 100%;
    height: min(72vh, 760px);
    border: 0;
    border-radius: 12px;
    background: #ffffff;
}

/* Configuracion de estilos */
body.style-config-page {
    background: #eef7ff;
}

body.style-config-page #app {
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 80px);
}

body.style-config-page .main-content {
    flex: 1 0 auto;
}

body.style-config-page .footer-cyber {
    flex-shrink: 0;
    margin-top: auto;
}

.style-config-page .container-cyberpunk {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(0, 166, 214, 0.16);
    box-shadow: 0 18px 42px rgba(10, 61, 98, 0.12);
}

.style-config-page .neon-title-cyberpunk {
    color: #0a3d62;
    text-shadow: none;
}

.style-config-page .neon-subtitle-cyber {
    color: #4b6378;
    text-shadow: none;
}

.style-config-card {
    border: 0;
    border-left: 7px solid #6a4cc2;
    border-radius: 18px;
    background: linear-gradient(135deg, #f4efff, #ffffff);
    color: #223242;
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.12);
}

.style-config-card h3,
.style-config-card .form-label,
.style-config-card .form-check-label {
    color: #0a3d62;
    font-weight: 800;
}

.style-config-page .form-control {
    color: #1f2f3f;
    background: #ffffff;
    border: 1px solid #b8cfda;
}

.style-config-page .form-control:focus {
    border-color: #6a4cc2;
    box-shadow: 0 0 0 0.2rem rgba(106, 76, 194, 0.16);
}

.style-color-field {
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 8px;
}

.style-color-field .form-control-color {
    width: 46px;
    padding: 4px;
}

.style-preview {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px;
    border: 1px solid;
}

.style-preview strong,
.style-preview span {
    display: block;
}

.style-preview button {
    border: 0;
    border-radius: 10px;
    padding: 10px 18px;
    color: #ffffff;
    font-weight: 900;
    background: linear-gradient(135deg, #00a6d6, #2abf88);
}

.style-config-primary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 18px;
    border: 0;
    border-radius: 10px;
    color: #ffffff;
    font-weight: 900;
    background: linear-gradient(135deg, #6a4cc2, #00a6d6);
    box-shadow: 0 10px 22px rgba(106, 76, 194, 0.2);
}

.style-config-table-wrapper {
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.1);
    overflow-x: auto;
}

.style-config-page table.dataTable thead {
    background: linear-gradient(135deg, #6a4cc2, #00a6d6);
}

.style-config-page table.dataTable thead th,
.style-config-page table.dataTable tbody td {
    text-align: left;
}

.style-config-page table.dataTable td:last-child {
    white-space: nowrap;
}

.style-swatch {
    width: 22px;
    height: 22px;
    display: inline-block;
    margin-right: 8px;
    vertical-align: middle;
    border-radius: 6px;
    border: 1px solid rgba(10, 61, 98, 0.18);
}

.staff-admin-page .container-cyberpunk {
    background: #f8fbff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 18px 40px rgba(10, 61, 98, 0.12);
}

.staff-admin-page .neon-title-cyberpunk {
    color: #0a3d62;
    text-shadow: none;
}

.staff-admin-page .neon-subtitle-cyber {
    color: #4b6378;
    text-shadow: none;
}

.staff-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 8px;
    margin: 0;
    list-style: none;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 12px 24px rgba(10, 61, 98, 0.08);
}

.staff-tab-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    padding: 10px 18px;
    border: 0;
    border-radius: 12px;
    font-weight: 800;
    color: #25384c;
    background: #eef4f8;
    transition: transform 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, background 0.2s ease;
}

.staff-tab-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 22px rgba(10, 61, 98, 0.12);
}

.staff-tab-personas.active {
    color: #ffffff;
    background: linear-gradient(135deg, #007f8f, #2abf88);
    box-shadow: 0 12px 24px rgba(0, 127, 143, 0.25);
}

.staff-tab-funciones.active {
    color: #ffffff;
    background: linear-gradient(135deg, #6a4cc2, #ff8f3d);
    box-shadow: 0 12px 24px rgba(106, 76, 194, 0.22);
}

.staff-tab-horarios.active {
    color: #ffffff;
    background: linear-gradient(135deg, #0ea5e9, #14b8a6);
    box-shadow: 0 12px 24px rgba(14, 165, 233, 0.22);
}

.staff-tab-asistencia.active {
    color: #ffffff;
    background: linear-gradient(135deg, #16a34a, #f59e0b);
    box-shadow: 0 12px 24px rgba(22, 163, 74, 0.2);
}

.staff-admin-card {
    border: 0;
    border-radius: 18px;
    color: #223242;
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.12);
}

.staff-person-card {
    background: linear-gradient(135deg, #e6fbf6, #f8fffb);
    border-left: 6px solid #00a783;
}

.staff-function-card {
    background: linear-gradient(135deg, #fff4e8, #f4efff);
    border-left: 6px solid #8a5cf6;
}

.staff-schedule-card {
    background: linear-gradient(135deg, #e8f7ff, #eefdf8);
    border-left: 6px solid #0ea5e9;
}

.staff-attendance-card {
    background: linear-gradient(135deg, #ecfdf3, #fff7e6);
    border-left: 6px solid #16a34a;
}

.staff-attendance-backup-card {
    background: linear-gradient(135deg, #fff7ed, #f8fbff);
    border-left: 6px solid #f59e0b;
}

.staff-admin-card h3 {
    color: #0a3d62;
    font-weight: 900;
}

.staff-admin-card .form-label,
.staff-admin-card .form-check-label {
    color: #31475c;
    font-weight: 800;
}

.staff-admin-page .form-control,
.staff-admin-page .form-select {
    color: #1f2f3f;
    background: #ffffff;
    border: 1px solid #b8cfda;
}

.staff-admin-page .form-control:focus,
.staff-admin-page .form-select:focus {
    border-color: #00a6d6;
    box-shadow: 0 0 0 0.2rem rgba(0, 166, 214, 0.16);
}

.staff-primary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 18px;
    border: 0;
    border-radius: 10px;
    color: #ffffff;
    font-weight: 900;
}

.staff-person-btn {
    background: linear-gradient(135deg, #007f8f, #2abf88);
    box-shadow: 0 10px 22px rgba(0, 127, 143, 0.22);
}

.staff-function-btn {
    background: linear-gradient(135deg, #6a4cc2, #ff8f3d);
    box-shadow: 0 10px 22px rgba(106, 76, 194, 0.2);
}

.staff-schedule-btn {
    background: linear-gradient(135deg, #0ea5e9, #14b8a6);
    box-shadow: 0 10px 22px rgba(14, 165, 233, 0.2);
}

.staff-attendance-in-btn {
    background: linear-gradient(135deg, #16a34a, #22c55e);
    box-shadow: 0 10px 22px rgba(22, 163, 74, 0.2);
}

.staff-attendance-out-btn {
    background: linear-gradient(135deg, #f59e0b, #ef4444);
    box-shadow: 0 10px 22px rgba(245, 158, 11, 0.2);
}

.staff-table-wrapper {
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.1);
}

.staff-person-table table.dataTable thead {
    background: linear-gradient(135deg, #007f8f, #2abf88);
}

.staff-function-table table.dataTable thead {
    background: linear-gradient(135deg, #6a4cc2, #ff8f3d);
}

.staff-schedule-table table.dataTable thead {
    background: linear-gradient(135deg, #0ea5e9, #14b8a6);
}

.staff-attendance-table table.dataTable thead {
    background: linear-gradient(135deg, #16a34a, #f59e0b);
}

.staff-calendar-subtitle {
    color: #4b6378;
    font-weight: 700;
}

.staff-calendar-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    color: #31475c;
    font-size: 0.88rem;
    font-weight: 800;
}

.staff-calendar-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.staff-dot {
    width: 10px;
    height: 10px;
    display: inline-block;
    border-radius: 999px;
}

.staff-dot-ok {
    background: #22c55e;
}

.staff-dot-late {
    background: #ef4444;
}

.staff-dot-missing {
    background: #94a3b8;
}

.staff-attendance-control-btn {
    background: linear-gradient(135deg, #0ea5e9, #16a34a);
    box-shadow: 0 10px 22px rgba(14, 165, 233, 0.2);
}

.staff-calendar-panel {
    padding: 18px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 14px 32px rgba(10, 61, 98, 0.1);
    overflow-x: auto;
}

.staff-calendar-empty {
    min-height: 220px;
    display: grid;
    place-items: center;
    gap: 12px;
    color: #4b6378;
    text-align: center;
    font-weight: 900;
}

.staff-calendar-empty i {
    font-size: 2.2rem;
    color: #0ea5e9;
}

.staff-calendar-header {
    display: grid;
    grid-template-columns: 44px 1fr 44px;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}

.staff-calendar-header div {
    text-align: center;
}

.staff-calendar-header strong {
    display: block;
    color: #0a3d62;
    font-size: 1.15rem;
    font-weight: 950;
}

.staff-calendar-header span {
    display: block;
    color: #587189;
    font-weight: 800;
    text-transform: capitalize;
}

.staff-calendar-nav {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 12px;
    color: #ffffff;
    background: linear-gradient(135deg, #0ea5e9, #14b8a6);
    box-shadow: 0 10px 20px rgba(14, 165, 233, 0.2);
}

.staff-calendar-weekdays,
.staff-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(112px, 1fr));
    gap: 8px;
}

.staff-calendar-weekdays {
    margin-bottom: 8px;
}

.staff-calendar-weekdays span {
    padding: 10px;
    border-radius: 10px;
    color: #ffffff;
    background: linear-gradient(135deg, #0a3d62, #0ea5e9);
    text-align: center;
    font-weight: 900;
}

.staff-calendar-day {
    min-height: 150px;
    padding: 10px;
    border-radius: 14px;
    border: 1px solid rgba(10, 61, 98, 0.12);
    background: #f8fbff;
    color: #23364a;
    overflow: hidden;
}

.staff-calendar-day.is-outside {
    background: transparent;
    border-color: transparent;
}

.staff-calendar-day-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}

.staff-calendar-day-head strong {
    color: #0a3d62;
    font-size: 1.15rem;
    font-weight: 950;
}

.staff-calendar-day-head span {
    color: #5b7085;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.staff-calendar-hours {
    display: grid;
    gap: 5px;
    font-size: 0.8rem;
    font-weight: 800;
}

.staff-calendar-hours span {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.staff-calendar-detail,
.staff-calendar-note {
    margin: 8px 0 0;
    font-size: 0.78rem;
    font-weight: 900;
}

.staff-calendar-note {
    padding-top: 8px;
    border-top: 1px solid rgba(10, 61, 98, 0.12);
    color: #52677c;
}

.staff-calendar-day.is-ok {
    background: #ecfdf3;
    border-color: #86efac;
}

.staff-calendar-day.is-late,
.staff-calendar-day.is-early {
    background: #fff1f2;
    border-color: #fb7185;
}

.staff-calendar-day.is-open {
    background: #fffbeb;
    border-color: #fbbf24;
}

.staff-calendar-day.is-missing {
    background: #f1f5f9;
    border-color: #cbd5e1;
}

.staff-calendar-day.is-no-schedule {
    background: #eff6ff;
    border-color: #93c5fd;
}

.staff-calendar-day.is-unscheduled-present {
    background: #f0fdfa;
    border-color: #2dd4bf;
}

.staff-calendar-day.is-future {
    background: #f8fafc;
    border-color: #e2e8f0;
    opacity: 0.78;
}

.staff-attendance-self-page .staff-self-shell {
    min-height: calc(100vh - 180px);
}

.staff-self-kicker {
    display: inline-block;
    margin-bottom: 4px;
    color: #16a34a;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.staff-location-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(10, 61, 98, 0.14);
    background: #f8fbff;
}

.staff-location-card h4 {
    color: #0a3d62;
    font-weight: 900;
}

.staff-location-card p {
    color: #4b6378;
    font-weight: 800;
}

.staff-location-ok {
    background: linear-gradient(135deg, #ecfdf3, #f8fffb);
    border-color: #86efac;
}

.staff-location-out {
    background: linear-gradient(135deg, #fff1f2, #fff7ed);
    border-color: #fb7185;
}

.staff-location-pending {
    background: linear-gradient(135deg, #eff6ff, #f8fbff);
    border-color: #93c5fd;
}

.staff-attendance-in-btn:disabled,
.staff-attendance-out-btn:disabled,
.staff-attendance-control-btn:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    box-shadow: none;
}

.staff-admin-page table.dataTable thead th,
.staff-admin-page table.dataTable tbody td {
    text-align: left;
}

.staff-admin-page table.dataTable tbody td {
    color: #27384a;
}

.staff-admin-page .dataTables_wrapper,
.staff-admin-page .dataTables_filter label,
.staff-admin-page .dataTables_length label,
.staff-admin-page .dataTables_info {
    color: #31475c;
}

.staff-admin-page .dataTables_filter input,
.staff-admin-page .dataTables_length select {
    color: #1f2f3f;
    background: #ffffff;
    border: 1px solid #b8cfda;
}

.staff-photo-preview {
    width: 96px;
    height: 96px;
    object-fit: cover;
    border-radius: 16px;
    border: 3px solid #ffffff;
    box-shadow: 0 10px 24px rgba(10, 61, 98, 0.16);
}

.staff-table-photo,
.staff-avatar-placeholder {
    width: 42px;
    height: 42px;
    border-radius: 50%;
}

.staff-table-photo {
    object-fit: cover;
    border: 2px solid rgba(0, 127, 143, 0.28);
}

.staff-avatar-placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-weight: 900;
    background: linear-gradient(135deg, #007f8f, #2abf88);
}

.staff-payroll-card {
    background: linear-gradient(135deg, #eff7ff, #f7fff4);
    border-left: 6px solid #1c7ed6;
}

.staff-payroll-btn {
    background: linear-gradient(135deg, #1c7ed6, #37b24d);
    box-shadow: 0 10px 22px rgba(28, 126, 214, 0.2);
}

.staff-payroll-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.staff-payroll-summary article {
    padding: 18px;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid rgba(10, 61, 98, 0.12);
    box-shadow: 0 12px 26px rgba(10, 61, 98, 0.08);
}

.staff-payroll-summary span {
    display: block;
    color: #526a7f;
    font-weight: 800;
}

.staff-payroll-summary strong {
    display: block;
    margin-top: 6px;
    color: #0a3d62;
    font-size: 1.45rem;
    font-weight: 900;
}

.staff-payroll-table table.dataTable thead {
    background: linear-gradient(135deg, #1c7ed6, #37b24d);
}

.staff-modal-content {
    background: #f7fff4;
    color: #0a2035;
    border: 1px solid rgba(28, 126, 214, 0.28);
    box-shadow: 0 22px 46px rgba(10, 61, 98, 0.22);
}

.staff-modal-content .modal-header {
    background: linear-gradient(135deg, #1c7ed6, #37b24d);
    color: #ffffff;
}

.staff-modal-content .modal-title {
    font-weight: 900;
}

.staff-modal-content .dataTables_filter {
    text-align: right;
}

.staff-modal-content .dataTables_filter label {
    max-width: 100%;
}

.staff-modal-content .dataTables_filter input {
    max-width: min(100%, 260px);
}

/* Tema activo desde configuracion */
html[data-fusion-theme] body {
    background: var(--fusion-bg) !important;
    background-color: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
    font-family: var(--fusion-font), system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html[data-fusion-theme] body.datatable-page,
html[data-fusion-theme] body.global-page,
html[data-fusion-theme] body.staff-admin-page,
html[data-fusion-theme] body.private-classes-admin-page,
html[data-fusion-theme] body.private-classes-user-page,
html[data-fusion-theme] body.style-config-page,
html[data-fusion-theme] body.nutrition-admin-page,
html[data-fusion-theme] body.asistencia-page,
html[data-fusion-theme] body.asistencia-inactivos-page,
html[data-fusion-theme] body.confirmacion-pagos-page,
html[data-fusion-theme] body.asistencia-presencial-page,
html[data-fusion-theme] body.asistencia-mensual-page,
html[data-fusion-theme] body.qr-gym-page,
html[data-fusion-theme] body.ejercicios-user-page,
html[data-fusion-theme] body.story-user-page,
html[data-fusion-theme] body.stories-admin-page,
html[data-fusion-theme] body.whatsapp-admin-page,
html[data-fusion-theme] body.communities-page,
html[data-fusion-theme] body.community-detail-page,
html[data-fusion-theme] body.communities-admin-page {
    background: var(--fusion-bg) !important;
    background-color: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .cc-socios-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    border-radius: var(--fusion-radius);
    box-shadow: var(--fusion-shadow);
}

html[data-fusion-theme] .cc-socio-summary-card,
html[data-fusion-theme] .cc-socio-summary-item,
html[data-fusion-theme] .cc-socios-page .filtros-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .cc-socio-summary-card h4,
html[data-fusion-theme] .cc-socios-page .filtros-card h6 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .cc-table-wrapper {
    padding: 1rem;
}

html[data-fusion-theme] table.dataTable tbody tr.fila-impago > td {
    background-color: color-mix(in srgb, #dc3545, var(--fusion-table-row-bg) 76%) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] table.dataTable tbody tr.fila-pendiente > td {
    background-color: color-mix(in srgb, #ffc107, var(--fusion-table-row-bg) 74%) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] table.dataTable tbody tr.fila-pagado > td {
    background-color: color-mix(in srgb, #198754, var(--fusion-table-row-bg) 78%) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .cc-socios-page .estado-pagado {
    color: var(--fusion-secondary) !important;
    font-weight: 800;
}

html[data-fusion-theme] .finance-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    border-radius: var(--fusion-radius);
    box-shadow: var(--fusion-shadow);
}

html[data-fusion-theme] .finance-page .row.g-3.mb-4 .card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 66%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .finance-page .row.g-3.mb-4 .card h6 {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .finance-page .row.g-3.mb-4 .card h3 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] body::before {
    opacity: 0.04;
}

html[data-fusion-theme] .main-content {
    background: transparent !important;
}

html[data-fusion-theme] .cyber-form,
html[data-fusion-theme] .cyber-form-dark,
html[data-fusion-theme] .glass-card,
html[data-fusion-theme] .card-cyber {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 65%) !important;
    border-radius: var(--fusion-radius);
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .cyber-form .container,
html[data-fusion-theme] .cyber-form-dark .container,
html[data-fusion-theme] .position-relative {
    background: transparent !important;
}

html[data-fusion-theme] .cyber-form h1,
html[data-fusion-theme] .cyber-form-dark h1,
html[data-fusion-theme] .glass-card h1,
html[data-fusion-theme] .cyber-form h3,
html[data-fusion-theme] .cyber-form-dark h3,
html[data-fusion-theme] .glass-card h3 {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .cyber-form h5,
html[data-fusion-theme] .cyber-form-dark h5,
html[data-fusion-theme] .glass-card h5 {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .cyber-form label,
html[data-fusion-theme] .cyber-form-dark label,
html[data-fusion-theme] .form-label,
html[data-fusion-theme] .form-check-label {
    color: var(--fusion-text) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .form-control,
html[data-fusion-theme] .form-select,
html[data-fusion-theme] .cyber-form .form-control,
html[data-fusion-theme] .cyber-form-dark .form-control,
html[data-fusion-theme] .cyber-form .form-select,
html[data-fusion-theme] .cyber-form-dark .form-select {
    background-color: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 20%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .form-control:focus,
html[data-fusion-theme] .form-select:focus,
html[data-fusion-theme] .cyber-form .form-control:focus,
html[data-fusion-theme] .cyber-form-dark .form-control:focus,
html[data-fusion-theme] .cyber-form .form-select:focus,
html[data-fusion-theme] .cyber-form-dark .form-select:focus {
    background-color: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 12%) !important;
    color: var(--fusion-text) !important;
    border-color: var(--fusion-secondary) !important;
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
}

html[data-fusion-theme] .form-control::placeholder {
    color: color-mix(in srgb, var(--fusion-text), transparent 42%) !important;
}

html[data-fusion-theme] .navbar.fixed-top,
html[data-fusion-theme] .navbar-cyberpunk {
    background: var(--fusion-primary) !important;
}

html[data-fusion-theme] .navbar .nav-link:hover,
html[data-fusion-theme] .navbar .nav-link.active,
html[data-fusion-theme] .navbar-cyberpunk .nav-link:hover,
html[data-fusion-theme] .navbar-cyberpunk .nav-link.active {
    color: var(--fusion-secondary) !important;
    text-shadow: 0 0 8px color-mix(in srgb, var(--fusion-secondary), transparent 25%);
}

html[data-fusion-theme] .container-cyberpunk,
html[data-fusion-theme] .staff-admin-page .container-cyberpunk,
html[data-fusion-theme] .private-classes-admin-page .container-cyberpunk,
html[data-fusion-theme] .private-classes-user-page .container-cyberpunk,
html[data-fusion-theme] .style-config-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%);
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%);
    border-radius: var(--fusion-radius);
    box-shadow: var(--fusion-shadow);
}

html[data-fusion-theme] .global-location-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 10%) !important;
    color: var(--fusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 70%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .global-location-card h6,
html[data-fusion-theme] .global-location-card .form-label,
html[data-fusion-theme] .global-location-card label,
html[data-fusion-theme] .global-location-card small,
html[data-fusion-theme] .global-location-card .text-muted {
    color: var(--fusion-text) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .global-location-card .input-group-text {
    background-color: color-mix(in srgb, var(--fusion-primary), var(--fusion-surface) 30%) !important;
    color: var(--fusion-secondary) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .global-location-card #mapa {
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 58%) !important;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--fusion-primary), transparent 70%) !important;
}

html[data-fusion-theme] .style-config-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-left-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .style-config-card h3,
html[data-fusion-theme] .style-config-card .form-label,
html[data-fusion-theme] .style-config-card .form-check-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .style-color-field .form-control-color {
    background-color: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 14%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 50%) !important;
}

html[data-fusion-theme] .style-preview {
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .style-preview button {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .style-config-page .text-muted {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .style-swatch {
    border-color: color-mix(in srgb, var(--fusion-text), transparent 68%) !important;
}

html[data-fusion-theme] .finance-expense-card,
html[data-fusion-theme] .finance-income-card,
html[data-fusion-theme] .finance-outcome-card,
html[data-fusion-theme] .finance-category-card,
html[data-fusion-theme] .finance-close-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-top-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .finance-income-card {
    background:
        linear-gradient(135deg, color-mix(in srgb, #198754, transparent 86%), color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%)) !important;
    border-color: color-mix(in srgb, #198754, transparent 55%) !important;
    border-top-color: #198754 !important;
}

html[data-fusion-theme] .finance-outcome-card {
    background:
        linear-gradient(135deg, color-mix(in srgb, #dc3545, transparent 86%), color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%)) !important;
    border-color: color-mix(in srgb, #dc3545, transparent 55%) !important;
    border-top-color: #dc3545 !important;
}

html[data-fusion-theme] .finance-category-card {
    background:
        linear-gradient(135deg, color-mix(in srgb, #6f42c1, transparent 84%), color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%)) !important;
    border-color: color-mix(in srgb, #6f42c1, transparent 55%) !important;
    border-top-color: #6f42c1 !important;
}

html[data-fusion-theme] .finance-close-card {
    background:
        linear-gradient(135deg, color-mix(in srgb, #f59f00, transparent 84%), color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%)) !important;
    border-color: color-mix(in srgb, #f59f00, transparent 55%) !important;
    border-top-color: #f59f00 !important;
}

html[data-fusion-theme] .finance-expense-card h3,
html[data-fusion-theme] .finance-income-card h3,
html[data-fusion-theme] .finance-outcome-card h3,
html[data-fusion-theme] .finance-category-card h3,
html[data-fusion-theme] .finance-close-card h3,
html[data-fusion-theme] .finance-expense-card .form-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .finance-income-card h3,
html[data-fusion-theme] .finance-income-card h3 i {
    color: #198754 !important;
}

html[data-fusion-theme] .finance-outcome-card h3,
html[data-fusion-theme] .finance-outcome-card h3 i {
    color: #dc3545 !important;
}

html[data-fusion-theme] .finance-category-card h3,
html[data-fusion-theme] .finance-category-card h3 i {
    color: #6f42c1 !important;
}

html[data-fusion-theme] .finance-close-card h3,
html[data-fusion-theme] .finance-close-card h3 i {
    color: #f59f00 !important;
}

html[data-fusion-theme] .finance-chart-panel {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 12%) !important;
    border-color: color-mix(in srgb, #f59f00, transparent 62%) !important;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--fusion-text), transparent 88%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-link {
    color: var(--fusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 74%) !important;
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 10%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(1) .nav-link {
    border-color: color-mix(in srgb, #198754, transparent 60%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(2) .nav-link {
    border-color: color-mix(in srgb, #dc3545, transparent 60%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(3) .nav-link {
    border-color: color-mix(in srgb, #6f42c1, transparent 58%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(4) .nav-link {
    border-color: color-mix(in srgb, #f59f00, transparent 58%) !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(1) .nav-link.active {
    background: linear-gradient(135deg, #20c997, #198754) !important;
    color: #ffffff !important;
    border-color: #198754 !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(2) .nav-link.active {
    background: linear-gradient(135deg, #ff6b6b, #dc3545) !important;
    color: #ffffff !important;
    border-color: #dc3545 !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(3) .nav-link.active {
    background: linear-gradient(135deg, #0dcaf0, #6f42c1) !important;
    color: #ffffff !important;
    border-color: #6f42c1 !important;
}

html[data-fusion-theme] .finance-tabs .nav-item:nth-child(4) .nav-link.active {
    background: linear-gradient(135deg, #ffd43b, #0b7285) !important;
    color: #ffffff !important;
    border-color: #f59f00 !important;
}

html[data-fusion-theme] .staff-tabs {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 76%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .staff-tab-btn {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 16%) !important;
    color: var(--fusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
}

html[data-fusion-theme] .staff-tab-btn.active,
html[data-fusion-theme] .staff-tab-personas.active,
html[data-fusion-theme] .staff-tab-funciones.active {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
    box-shadow: 0 12px 24px color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
}

html[data-fusion-theme] .staff-admin-card,
html[data-fusion-theme] .staff-person-card,
html[data-fusion-theme] .staff-function-card,
html[data-fusion-theme] .staff-payroll-card,
html[data-fusion-theme] .staff-attendance-backup-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-left-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .staff-admin-card h3,
html[data-fusion-theme] .staff-admin-card .form-label,
html[data-fusion-theme] .staff-admin-card .form-check-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .staff-calendar-subtitle,
html[data-fusion-theme] .staff-calendar-legend,
html[data-fusion-theme] .staff-calendar-empty,
html[data-fusion-theme] .staff-calendar-header span,
html[data-fusion-theme] .staff-calendar-day-head span,
html[data-fusion-theme] .staff-calendar-note {
    color: var(--fusion-muted) !important;
}

html[data-fusion-theme] .staff-calendar-panel {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .staff-calendar-header strong,
html[data-fusion-theme] .staff-calendar-day-head strong {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .staff-calendar-weekdays span,
html[data-fusion-theme] .staff-calendar-nav {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .staff-calendar-day {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 12%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
}

html[data-fusion-theme] .staff-calendar-day.is-ok {
    background: color-mix(in srgb, #22c55e, var(--fusion-surface) 82%) !important;
    border-color: color-mix(in srgb, #22c55e, transparent 35%) !important;
}

html[data-fusion-theme] .staff-calendar-day.is-late,
html[data-fusion-theme] .staff-calendar-day.is-early {
    background: color-mix(in srgb, #ef4444, var(--fusion-surface) 78%) !important;
    border-color: color-mix(in srgb, #ef4444, transparent 25%) !important;
}

html[data-fusion-theme] .staff-calendar-day.is-open {
    background: color-mix(in srgb, #f59e0b, var(--fusion-surface) 78%) !important;
    border-color: color-mix(in srgb, #f59e0b, transparent 30%) !important;
}

html[data-fusion-theme] .staff-calendar-day.is-missing,
html[data-fusion-theme] .staff-calendar-day.is-future {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
}

html[data-fusion-theme] .staff-calendar-day.is-no-schedule,
html[data-fusion-theme] .staff-calendar-day.is-unscheduled-present {
    background: color-mix(in srgb, var(--fusion-secondary), var(--fusion-surface) 84%) !important;
}

html[data-fusion-theme] .staff-location-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 10%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 70%) !important;
}

html[data-fusion-theme] .staff-location-card h4 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .staff-location-card p {
    color: var(--fusion-muted) !important;
}

html[data-fusion-theme] .staff-location-ok {
    background: color-mix(in srgb, #22c55e, var(--fusion-surface) 82%) !important;
    border-color: color-mix(in srgb, #22c55e, transparent 35%) !important;
}

html[data-fusion-theme] .staff-location-out {
    background: color-mix(in srgb, #ef4444, var(--fusion-surface) 78%) !important;
    border-color: color-mix(in srgb, #ef4444, transparent 25%) !important;
}

html[data-fusion-theme] .staff-location-pending {
    background: color-mix(in srgb, var(--fusion-secondary), var(--fusion-surface) 86%) !important;
}

html[data-fusion-theme] .staff-photo-preview,
html[data-fusion-theme] .staff-table-photo {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 14%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 48%) !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 74%) !important;
}

html[data-fusion-theme] .staff-avatar-placeholder {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .staff-payroll-summary article {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .staff-payroll-summary span {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .staff-payroll-summary strong {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .staff-modal-content {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 60%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .staff-modal-content .modal-header {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .staff-modal-content .btn-close {
    filter: invert(1) grayscale(1) brightness(2);
}

html[data-fusion-theme] .qr-gym-panel {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .qr-display-card,
html[data-fusion-theme] .qr-settings-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .qr-settings-card h2,
html[data-fusion-theme] .qr-settings-card .form-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .qr-print-sheet {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 58%) !important;
    border-radius: var(--fusion-radius) !important;
}

html[data-fusion-theme] .qr-print-sheet h2 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .qr-print-sheet p,
html[data-fusion-theme] .qr-print-sheet small {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .qr-gym-container {
    background: #ffffff !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 74%) !important;
}

html[data-fusion-theme] .qr-payload-preview {
    background: color-mix(in srgb, var(--fusion-table-row-alt-bg), var(--fusion-surface) 20%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
}

html[data-fusion-theme] .qr-payload-preview pre {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .whatsapp-admin-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .whatsapp-admin-page .container-cyberpunk,
html[data-fusion-theme] .whatsapp-config-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-top-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .whatsapp-config-card .form-label,
html[data-fusion-theme] .whatsapp-config-card .form-check-label,
html[data-fusion-theme] .whatsapp-config-card .text-muted {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .whatsapp-admin-page table thead {
    background: linear-gradient(135deg, var(--fusion-table-head-bg), var(--fusion-secondary)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .whatsapp-admin-page table td {
    background-color: var(--fusion-table-row-bg) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 84%) !important;
}

html[data-fusion-theme] .whatsapp-admin-page table tbody tr:nth-child(even) td {
    background-color: var(--fusion-table-row-alt-bg) !important;
}

html[data-fusion-theme] .private-classes-admin-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .private-class-admin-card,
html[data-fusion-theme] .private-class-enrollment-card,
html[data-fusion-theme] .private-class-enrollment-form {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-left-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .private-class-admin-card h3,
html[data-fusion-theme] .private-class-enrollment-form h4,
html[data-fusion-theme] .private-class-admin-card .form-label,
html[data-fusion-theme] .private-class-admin-card .form-check-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .private-class-enrollment-card .text-muted {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .private-classes-admin-page table.dataTable.dtr-inline.collapsed > tbody > tr > td.dtr-control::before,
html[data-fusion-theme] .private-classes-admin-page table.dataTable.dtr-inline.collapsed > tbody > tr > th.dtr-control::before {
    background-color: var(--fusion-secondary) !important;
    box-shadow: 0 4px 10px color-mix(in srgb, var(--fusion-secondary), transparent 70%) !important;
}

html[data-fusion-theme] .nutrition-admin-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .nutrition-admin-page .container-cyberpunk,
html[data-fusion-theme] .nutrition-admin-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-top-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .nutrition-admin-card h3,
html[data-fusion-theme] .nutrition-admin-card .form-label,
html[data-fusion-theme] .nutrition-admin-card .form-check-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .nutrition-admin-page .training-admin-preview,
html[data-fusion-theme] .nutrition-admin-page .training-table-thumb {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 16%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 58%) !important;
}

html[data-fusion-theme] .asistencia-mensual-panel {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .asistencia-presencial-panel {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .presencial-search-card,
html[data-fusion-theme] .presencial-detail-card,
html[data-fusion-theme] .presencial-result,
html[data-fusion-theme] .selected-member {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 82%) !important;
}

html[data-fusion-theme] .presencial-search-card h2,
html[data-fusion-theme] .presencial-detail-card h2,
html[data-fusion-theme] .selected-member h3,
html[data-fusion-theme] .member-data dt,
html[data-fusion-theme] .empty-selection i {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .presencial-result:hover,
html[data-fusion-theme] .presencial-result.selected {
    border-color: var(--fusion-secondary) !important;
    box-shadow: 0 12px 26px color-mix(in srgb, var(--fusion-secondary), transparent 74%) !important;
}

html[data-fusion-theme] .presencial-result small,
html[data-fusion-theme] .member-number,
html[data-fusion-theme] .selected-member p,
html[data-fusion-theme] .empty-results,
html[data-fusion-theme] .empty-selection {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .member-data div {
    border-bottom-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
}

html[data-fusion-theme] .member-data dd {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .asistencia-presencial-page .input-group-text {
    background-color: color-mix(in srgb, var(--fusion-primary), var(--fusion-surface) 30%) !important;
    color: var(--fusion-secondary) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .calendar-toolbar,
html[data-fusion-theme] .attendance-summary div,
html[data-fusion-theme] .calendar-day {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 82%) !important;
}

html[data-fusion-theme] .calendar-toolbar h2,
html[data-fusion-theme] .attendance-summary span {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .calendar-toolbar p,
html[data-fusion-theme] .attendance-summary small,
html[data-fusion-theme] .calendar-legend {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .calendar-weekdays span {
    background: linear-gradient(135deg, var(--fusion-primary), var(--fusion-secondary)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .calendar-day.is-empty {
    background: color-mix(in srgb, var(--fusion-surface), transparent 78%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 82%) !important;
    box-shadow: none !important;
}

html[data-fusion-theme] .calendar-day.is-today {
    border-color: var(--fusion-accent) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--fusion-accent), transparent 78%) !important;
}

html[data-fusion-theme] .calendar-day.has-attendance {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 30%) !important;
    color: #ffffff !important;
    box-shadow:
        0 12px 24px color-mix(in srgb, var(--fusion-secondary), transparent 72%),
        inset 0 0 18px rgba(255, 255, 255, 0.18) !important;
}

html[data-fusion-theme] .day-number {
    background: color-mix(in srgb, var(--fusion-primary), var(--fusion-surface) 70%) !important;
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .calendar-day.has-attendance .day-number,
html[data-fusion-theme] .attendance-mark {
    background: rgba(255, 255, 255, 0.95) !important;
    color: var(--fusion-primary) !important;
}

html[data-fusion-theme] .story-user-page .container-cyberpunk,
html[data-fusion-theme] .stories-admin-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .story-submit-card,
html[data-fusion-theme] .story-admin-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-top-color: var(--fusion-secondary) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .story-submit-card .form-label,
html[data-fusion-theme] .story-admin-card h3,
html[data-fusion-theme] .story-admin-card .form-label,
html[data-fusion-theme] .story-admin-card .form-check-label {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .story-submit-preview {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 14%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 58%) !important;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--fusion-primary), transparent 70%) !important;
}

html[data-fusion-theme] .communities-page,
html[data-fusion-theme] .community-detail-page,
html[data-fusion-theme] .communities-admin-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .community-create-card,
html[data-fusion-theme] .community-invites,
html[data-fusion-theme] .community-post-form,
html[data-fusion-theme] .community-side-card,
html[data-fusion-theme] .community-admin-detail,
html[data-fusion-theme] .community-card,
html[data-fusion-theme] .community-post,
html[data-fusion-theme] .admin-community-post {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    border-radius: var(--fusion-radius) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .community-create-card {
    border-top-color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .community-create-card h2,
html[data-fusion-theme] .community-invites h2,
html[data-fusion-theme] .community-post-form h2,
html[data-fusion-theme] .community-side-card h2,
html[data-fusion-theme] .community-side-card h3,
html[data-fusion-theme] .community-admin-detail h2,
html[data-fusion-theme] .community-card h2,
html[data-fusion-theme] .community-post header,
html[data-fusion-theme] .community-comments h3 {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .community-card p,
html[data-fusion-theme] .community-post p,
html[data-fusion-theme] .community-admin-detail p,
html[data-fusion-theme] .admin-community-post p,
html[data-fusion-theme] .community-comment span {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .admin-community-comments h4 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .admin-community-comment {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .admin-community-comment-header small,
html[data-fusion-theme] .admin-community-empty-comments {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .community-card small,
html[data-fusion-theme] .community-member-row small,
html[data-fusion-theme] .community-hero small,
html[data-fusion-theme] .community-post header small {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .community-card img {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
}

html[data-fusion-theme] .community-actions .btn-training-detail,
html[data-fusion-theme] .exercise-catalog-card .btn-training-detail,
html[data-fusion-theme] .btn-training-detail {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    border-color: var(--fusion-secondary) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--fusion-secondary), transparent 76%) !important;
}

html[data-fusion-theme] .community-actions .btn-training-detail:hover,
html[data-fusion-theme] .exercise-catalog-card .btn-training-detail:hover,
html[data-fusion-theme] .btn-training-detail:hover {
    color: #ffffff !important;
    box-shadow: 0 14px 28px color-mix(in srgb, var(--fusion-secondary), transparent 68%) !important;
}

html[data-fusion-theme] .community-invite-row,
html[data-fusion-theme] .community-member-row,
html[data-fusion-theme] .community-comment {
    background: color-mix(in srgb, var(--fusion-table-row-alt-bg), var(--fusion-surface) 28%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 76%) !important;
}

html[data-fusion-theme] .community-comments {
    border-top-color: color-mix(in srgb, var(--fusion-secondary), transparent 74%) !important;
}

html[data-fusion-theme] .community-hero {
    background: linear-gradient(135deg, var(--fusion-primary), var(--fusion-secondary)) !important;
    color: #ffffff !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .community-hero h1,
html[data-fusion-theme] .community-hero p,
html[data-fusion-theme] .community-hero small {
    color: #ffffff !important;
}

html[data-fusion-theme] .communities-admin-page table.dataTable thead {
    background: linear-gradient(135deg, var(--fusion-table-head-bg), var(--fusion-secondary)) !important;
}

html[data-fusion-theme] .profile-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .profile-page .cyber-form h3 {
    color: var(--fusion-title) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .profile-page .cyber-form .container {
    border-bottom: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 82%);
    padding-bottom: 18px;
}

html[data-fusion-theme] .profile-page .cyber-form .container:last-of-type {
    border-bottom: 0;
}

html[data-fusion-theme] .profile-page .custom-file-label {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    border-color: var(--fusion-secondary) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .profile-page .file-input:valid + .custom-file-label {
    background: linear-gradient(135deg, var(--fusion-accent), var(--fusion-secondary)) !important;
    border-color: var(--fusion-accent) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .profile-page .preview-img,
html[data-fusion-theme] .profile-page .cyber-form img.img-thumbnail {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 35%) !important;
    box-shadow: 0 12px 26px color-mix(in srgb, var(--fusion-primary), transparent 72%) !important;
}

html[data-fusion-theme] .profile-page .btn-password {
    border-color: var(--fusion-accent) !important;
    color: var(--fusion-accent) !important;
}

html[data-fusion-theme] .profile-page .btn-password:hover {
    background: var(--fusion-accent) !important;
    color: #ffffff !important;
    box-shadow: 0 0 10px color-mix(in srgb, var(--fusion-accent), transparent 45%) !important;
}

html[data-fusion-theme] .training-admin-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .training-admin-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .fusion-tabs .nav-link {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 12%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    color: var(--fusion-title) !important;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--fusion-primary), transparent 86%) !important;
}

html[data-fusion-theme] .fusion-tabs .nav-link.active,
html[data-fusion-theme] .fusion-tabs .nav-item:nth-child(2) .nav-link.active {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
    border-color: transparent !important;
}

html[data-fusion-theme] .training-admin-card,
html[data-fusion-theme] .workout-admin-card,
html[data-fusion-theme] .exercise-admin-card,
html[data-fusion-theme] .training-day-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .workout-admin-card {
    border-top-color: var(--fusion-accent) !important;
}

html[data-fusion-theme] .exercise-admin-card {
    border-top-color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .training-admin-card h3,
html[data-fusion-theme] .training-admin-card h4,
html[data-fusion-theme] .training-admin-card .form-label,
html[data-fusion-theme] .training-admin-card .form-check-label,
html[data-fusion-theme] .training-admin-card .text-muted {
    color: var(--fusion-text) !important;
    text-shadow: none !important;
}

html[data-fusion-theme] .training-admin-card h3,
html[data-fusion-theme] .training-admin-card h4 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .training-admin-page .form-control,
html[data-fusion-theme] .training-admin-page .form-select {
    background-color: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 20%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .training-admin-page .form-control:focus,
html[data-fusion-theme] .training-admin-page .form-select:focus {
    background-color: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 12%) !important;
    color: var(--fusion-text) !important;
    border-color: var(--fusion-secondary) !important;
    box-shadow: 0 0 0 0.22rem color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
}

html[data-fusion-theme] .training-admin-preview,
html[data-fusion-theme] .training-table-thumb {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 35%) !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 78%) !important;
}

html[data-fusion-theme] .exercise-video-preview {
    background: #000000 !important;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--fusion-primary), transparent 78%) !important;
}

html[data-fusion-theme] .training-admin-page .table-wrapper-cyber {
    background: var(--fusion-table-wrapper-bg) !important;
    border-color: color-mix(in srgb, var(--fusion-primary), transparent 86%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .training-admin-page table.dataTable thead,
html[data-fusion-theme] .exercise-admin-card table.dataTable thead,
html[data-fusion-theme] .workout-admin-card table.dataTable thead {
    background: linear-gradient(135deg, var(--fusion-table-head-bg), var(--fusion-secondary)) !important;
}

html[data-fusion-theme] .training-admin-page .dataTables_wrapper,
html[data-fusion-theme] .training-admin-page .dataTables_filter label,
html[data-fusion-theme] .training-admin-page .dataTables_length label,
html[data-fusion-theme] .training-admin-page .dataTables_info {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .training-admin-page .dataTables_filter input,
html[data-fusion-theme] .training-admin-page .dataTables_length select {
    background-color: var(--fusion-surface) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] .routine-table {
    --bs-table-bg: var(--fusion-table-row-bg);
    --bs-table-striped-bg: var(--fusion-table-row-alt-bg);
    --bs-table-color: var(--fusion-text);
    --bs-table-border-color: color-mix(in srgb, var(--fusion-secondary), transparent 76%);
}

html[data-fusion-theme] .routine-table thead {
    background: linear-gradient(135deg, var(--fusion-table-head-bg), var(--fusion-secondary)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .ejercicios-user-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .ejercicios-user-panel {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .exercise-catalog-card,
html[data-fusion-theme] .empty-exercises {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .exercise-catalog-card:hover {
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 35%) !important;
    box-shadow: 0 22px 42px color-mix(in srgb, var(--fusion-primary), transparent 78%) !important;
}

html[data-fusion-theme] .exercise-catalog-image {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 18%) !important;
}

html[data-fusion-theme] .exercise-catalog-header i {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .exercise-catalog-header h2 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .exercise-catalog-description,
html[data-fusion-theme] .empty-exercises {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .exercise-no-video {
    background: color-mix(in srgb, var(--fusion-table-row-alt-bg), var(--fusion-surface) 25%) !important;
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .empty-exercises i {
    color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .exercise-video-modal {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .exercise-video-modal .modal-header {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .exercise-video-modal .modal-header p,
html[data-fusion-theme] .exercise-video-modal .modal-title {
    color: #ffffff !important;
}

html[data-fusion-theme] .private-classes-user-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .private-classes-user-page .container-cyberpunk {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .private-class-user-card,
html[data-fusion-theme] .private-class-bank-card,
html[data-fusion-theme] .private-class-empty {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .private-class-user-card:hover {
    box-shadow: 0 22px 42px color-mix(in srgb, var(--fusion-primary), transparent 78%) !important;
}

html[data-fusion-theme] .private-class-icon {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .private-class-user-card h2,
html[data-fusion-theme] .private-class-bank-card h3,
html[data-fusion-theme] .private-class-empty h4 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .private-class-user-card small,
html[data-fusion-theme] .private-class-description,
html[data-fusion-theme] .private-class-bank-card p,
html[data-fusion-theme] .private-class-bank-card small,
html[data-fusion-theme] .private-class-empty {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .private-class-meta {
    background: color-mix(in srgb, var(--fusion-table-row-alt-bg), var(--fusion-surface) 25%) !important;
    color: var(--fusion-text) !important;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary), transparent 76%) !important;
}

html[data-fusion-theme] .private-class-meta strong,
html[data-fusion-theme] .private-class-bank-card i,
html[data-fusion-theme] .private-class-bank-card strong,
html[data-fusion-theme] .private-class-empty i {
    color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .private-class-pay-box .form-label {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .private-class-subscribe-btn:disabled {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-text) 28%) !important;
    color: color-mix(in srgb, #ffffff, var(--fusion-text) 12%) !important;
}

html[data-fusion-theme] .fusion-comprobante-modal {
    background: var(--fusion-surface) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 70%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .fusion-comprobante-header {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 14%) !important;
    border-bottom-color: color-mix(in srgb, var(--fusion-secondary), transparent 76%) !important;
}

html[data-fusion-theme] .fusion-comprobante-header h3 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .fusion-comprobante-header small {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .fusion-comprobante-body {
    background: color-mix(in srgb, var(--fusion-bg), var(--fusion-surface) 18%) !important;
}

html[data-fusion-theme] .asistencia-page {
    background: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .asistencia-panel {
    background: color-mix(in srgb, var(--fusion-surface), transparent 5%) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .asistencia-status,
html[data-fusion-theme] .qr-card,
html[data-fusion-theme] .asistencia-card {
    background: color-mix(in srgb, var(--fusion-surface), var(--fusion-bg) 8%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 72%) !important;
    box-shadow: var(--fusion-shadow) !important;
}

html[data-fusion-theme] .asistencia-status strong,
html[data-fusion-theme] .asistencia-card h2,
html[data-fusion-theme] .asistencia-card dt {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .asistencia-status p,
html[data-fusion-theme] .asistencia-card dd {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .asistencia-card dl div {
    border-bottom-color: color-mix(in srgb, var(--fusion-secondary), transparent 78%) !important;
}

html[data-fusion-theme] .asistencia-status.is-pending i,
html[data-fusion-theme] .asistencia-status.is-checking i {
    color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .asistencia-status.is-inside {
    background: color-mix(in srgb, #198754, var(--fusion-surface) 82%) !important;
    border-color: color-mix(in srgb, #198754, transparent 45%) !important;
}

html[data-fusion-theme] .asistencia-status.is-outside {
    background: color-mix(in srgb, #dc3545, var(--fusion-surface) 84%) !important;
    border-color: color-mix(in srgb, #dc3545, transparent 45%) !important;
}

html[data-fusion-theme] .qr-reader {
    background: color-mix(in srgb, var(--fusion-primary), #000 32%) !important;
}

html[data-fusion-theme] .qr-blocker {
    background: color-mix(in srgb, var(--fusion-primary), #000 20%) !important;
    color: #ffffff !important;
}

html[data-fusion-theme] .qr-blocker i {
    color: var(--fusion-secondary) !important;
}

html[data-fusion-theme] .neon-title-cyberpunk {
    color: var(--fusion-title);
    text-shadow: none;
}

html[data-fusion-theme] .neon-subtitle-cyber {
    color: var(--fusion-subtitle);
    text-shadow: none;
}

html[data-fusion-theme] .table-wrapper-cyber,
html[data-fusion-theme] .private-class-table-wrapper,
html[data-fusion-theme] .style-config-table-wrapper,
html[data-fusion-theme] .staff-table-wrapper {
    background: var(--fusion-table-wrapper-bg);
    border-color: color-mix(in srgb, var(--fusion-primary), transparent 86%);
    border-radius: var(--fusion-radius);
    box-shadow: var(--fusion-shadow);
}

html[data-fusion-theme] table.dataTable thead,
html[data-fusion-theme] .private-classes-admin-page table.dataTable thead,
html[data-fusion-theme] .style-config-page table.dataTable thead,
html[data-fusion-theme] .staff-person-table table.dataTable thead,
html[data-fusion-theme] .staff-function-table table.dataTable thead {
    background: linear-gradient(135deg, var(--fusion-table-head-bg), var(--fusion-secondary)) !important;
}

html[data-fusion-theme] table.dataTable tbody tr,
html[data-fusion-theme] table.dataTable tbody tr > td {
    background-color: var(--fusion-table-row-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] table.dataTable tbody tr:nth-child(even),
html[data-fusion-theme] table.dataTable tbody tr:nth-child(even) > td {
    background-color: var(--fusion-table-row-alt-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] table.dataTable thead th {
    color: #ffffff !important;
}

html[data-fusion-theme] .dataTables_wrapper,
html[data-fusion-theme] .dataTables_filter label,
html[data-fusion-theme] .dataTables_length label,
html[data-fusion-theme] .dataTables_info {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .dataTables_filter input,
html[data-fusion-theme] .dataTables_length select {
    background-color: var(--fusion-surface) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 45%) !important;
}

html[data-fusion-theme] table.dataTable tbody tr:hover,
html[data-fusion-theme] table.dataTable tbody tr:hover > td {
    background-color: color-mix(in srgb, var(--fusion-table-row-alt-bg), var(--fusion-secondary) 14%) !important;
}

html[data-fusion-theme] .btn-cyber-new,
html[data-fusion-theme] .private-class-primary-btn,
html[data-fusion-theme] .private-class-subscribe-btn,
html[data-fusion-theme] .style-config-primary-btn,
html[data-fusion-theme] .staff-primary-btn {
    background: linear-gradient(135deg, var(--fusion-secondary), var(--fusion-accent)) !important;
    border-color: var(--fusion-secondary) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--fusion-secondary), transparent 76%);
}

html[data-fusion-theme] .btn-cyber-back {
    color: var(--fusion-accent);
    border-color: var(--fusion-accent);
}

html[data-fusion-theme] .btn-cyber-back:hover {
    background: var(--fusion-accent);
    color: #ffffff;
}

html[data-fusion-theme] .sidebar {
    background: var(--fusion-sidebar-bg);
    color: var(--fusion-text);
}

html[data-fusion-theme] .sidebar-profile {
    background: var(--fusion-sidebar-profile-bg);
}

html[data-fusion-theme] .sidebar-footer {
    background: var(--fusion-sidebar-profile-bg) !important;
    border-top-color: color-mix(in srgb, var(--fusion-sidebar-text), transparent 82%) !important;
}

html[data-fusion-theme] .sidebar-avatar {
    border-color: var(--fusion-sidebar-active);
}

html[data-fusion-theme] .sidebar-username,
html[data-fusion-theme] .sidebar-link {
    color: var(--fusion-sidebar-text);
}

html[data-fusion-theme] .sidebar-link:hover {
    background: var(--fusion-sidebar-hover);
}

html[data-fusion-theme] .sidebar-link:hover i,
html[data-fusion-theme] .sidebar-link.active,
html[data-fusion-theme] .sidebar-link.active i,
html[data-fusion-theme] .sidebar-sublink:hover,
html[data-fusion-theme] .sidebar-sublink:hover i,
html[data-fusion-theme] .sidebar-sublink.active i {
    color: var(--fusion-sidebar-active);
}

html[data-fusion-theme] .sidebar-link i,
html[data-fusion-theme] .sidebar-sublink {
    color: color-mix(in srgb, var(--fusion-sidebar-text), transparent 28%);
}

html[data-fusion-theme] .sidebar-link.active::before {
    background: var(--fusion-sidebar-active);
}

html[data-fusion-theme] .sidebar-submenu {
    background: color-mix(in srgb, var(--fusion-sidebar-hover), transparent 35%);
    border-left-color: color-mix(in srgb, var(--fusion-sidebar-active), transparent 72%);
}

html[data-fusion-theme] .btn-sidebar-toggle {
    background: color-mix(in srgb, var(--fusion-secondary), transparent 84%);
    border-color: color-mix(in srgb, var(--fusion-secondary), transparent 60%);
    color: var(--fusion-secondary);
    box-shadow: 0 0 12px color-mix(in srgb, var(--fusion-secondary), transparent 60%);
}

html[data-fusion-theme] .footer-cyber {
    background: linear-gradient(135deg, var(--fusion-primary), color-mix(in srgb, var(--fusion-primary), #000 22%));
    border-top-color: var(--fusion-accent);
    box-shadow: 0 0 25px color-mix(in srgb, var(--fusion-accent), transparent 68%);
}

html[data-fusion-theme] .footer-title-neon,
html[data-fusion-theme] .footer-legal a {
    color: var(--fusion-accent);
    text-shadow: none;
}

html[data-fusion-theme] .footer-links a:hover,
html[data-fusion-theme] .footer-legal a:hover {
    color: var(--fusion-secondary) !important;
    text-shadow: none;
}

html[data-fusion-theme] .footer-developer {
    color: var(--fusion-accent) !important;
}

html[data-fusion-theme] .footer-developer img {
    background: color-mix(in srgb, #ffffff, var(--fusion-surface) 12%) !important;
}

/* Bootstrap mantiene sus colores semanticos */
html[data-fusion-theme] .btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #0d6efd;
    --bs-btn-border-color: #0d6efd;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0b5ed7;
    --bs-btn-hover-border-color: #0a58ca;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #0a58ca;
    --bs-btn-active-border-color: #0a53be;
}

html[data-fusion-theme] .btn-secondary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #6c757d;
    --bs-btn-border-color: #6c757d;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #5c636a;
    --bs-btn-hover-border-color: #565e64;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #565e64;
    --bs-btn-active-border-color: #51585e;
}

html[data-fusion-theme] .btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: #198754;
    --bs-btn-border-color: #198754;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #157347;
    --bs-btn-hover-border-color: #146c43;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #146c43;
    --bs-btn-active-border-color: #13653f;
}

html[data-fusion-theme] .btn-danger {
    --bs-btn-color: #fff;
    --bs-btn-bg: #dc3545;
    --bs-btn-border-color: #dc3545;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #bb2d3b;
    --bs-btn-hover-border-color: #b02a37;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #b02a37;
    --bs-btn-active-border-color: #a52834;
}

html[data-fusion-theme] .btn-warning {
    --bs-btn-color: #000;
    --bs-btn-bg: #ffc107;
    --bs-btn-border-color: #ffc107;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #ffca2c;
    --bs-btn-hover-border-color: #ffc720;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #ffcd39;
    --bs-btn-active-border-color: #ffc720;
}

html[data-fusion-theme] .btn-info {
    --bs-btn-color: #000;
    --bs-btn-bg: #0dcaf0;
    --bs-btn-border-color: #0dcaf0;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #31d2f2;
    --bs-btn-hover-border-color: #25cff2;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #3dd5f3;
    --bs-btn-active-border-color: #25cff2;
}

@media (max-width: 991px) {
    .community-hero,
    .community-detail-grid {
        grid-template-columns: 1fr;
    }

    .staff-tabs {
        display: grid;
        grid-template-columns: 1fr;
    }

    .staff-tab-btn {
        width: 100%;
    }

    .staff-payroll-summary {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 768px) and (max-width: 1199px) {
    .staff-calendar-panel {
        padding: 12px;
    }

    .staff-calendar-weekdays,
    .staff-calendar-grid {
        grid-template-columns: repeat(7, minmax(88px, 1fr));
        gap: 6px;
    }

    .staff-calendar-weekdays span {
        padding: 8px 4px;
        font-size: 0.78rem;
    }

    .staff-calendar-day {
        min-height: 132px;
        padding: 8px;
        border-radius: 11px;
    }

    .staff-calendar-day-head {
        margin-bottom: 6px;
    }

    .staff-calendar-day-head strong {
        font-size: 0.98rem;
    }

    .staff-calendar-day-head span {
        font-size: 0.68rem;
    }

    .staff-calendar-hours {
        gap: 4px;
        font-size: 0.7rem;
    }

    .staff-calendar-detail,
    .staff-calendar-note {
        margin-top: 6px;
        font-size: 0.68rem;
    }

    .staff-calendar-header {
        grid-template-columns: 38px 1fr 38px;
    }

    .staff-calendar-nav {
        width: 38px;
        height: 38px;
        border-radius: 10px;
    }
}

.admin-teacher-plans-page .admin-plans-card {
    border-color: color-mix(in srgb, var(--ng-accent, #00d4ff) 35%, transparent);
}

.admin-plans-stats .profesor-stat-card:nth-child(2) {
    border-color: rgba(38, 210, 139, 0.45);
}

.admin-plans-stats .profesor-stat-card:nth-child(3) {
    border-color: rgba(148, 163, 184, 0.45);
}

.admin-plans-stats {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.admin-plan-detail-modal {
    background: var(--ng-surface, #101827);
    color: var(--ng-text, #f8fafc);
    border: 1px solid color-mix(in srgb, var(--ng-accent, #00d4ff) 32%, transparent);
}

.admin-plan-detail-modal .modal-header,
.admin-plan-detail-modal .modal-footer {
    border-color: color-mix(in srgb, var(--ng-accent, #00d4ff) 24%, transparent);
}

.admin-plan-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

.admin-plan-detail-meta span,
.admin-plan-observations {
    background: color-mix(in srgb, var(--ng-surface-alt, #17233a) 86%, transparent);
    border: 1px solid color-mix(in srgb, var(--ng-accent, #00d4ff) 24%, transparent);
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
}

.admin-plan-observations {
    margin-bottom: 1rem;
}

.admin-plan-day {
    background: color-mix(in srgb, var(--ng-surface-alt, #17233a) 82%, transparent);
    border: 1px solid color-mix(in srgb, var(--ng-accent, #00d4ff) 24%, transparent);
    border-radius: 0.75rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.admin-plan-day-head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.admin-plan-day-head > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3.2rem;
    padding: 0.35rem 0.55rem;
    border-radius: 999px;
    color: #06111f;
    font-weight: 800;
    background: linear-gradient(135deg, #29d8ff, #6ee78f);
}

.admin-plan-day-head h6,
.admin-plan-exercise h6 {
    color: var(--ng-heading, var(--ng-accent, #00d4ff));
    font-weight: 800;
    margin: 0;
}

.admin-plan-day-head small,
.admin-plan-exercise small {
    color: var(--ng-text-muted, #b7c6d8);
}

.admin-plan-exercise-list {
    display: grid;
    gap: 0.75rem;
}

.admin-plan-followup {
    display: grid;
    gap: 1rem;
}

.admin-plan-socio {
    border: 1px solid color-mix(in srgb, var(--ng-accent, #00d4ff) 26%, transparent);
    border-radius: 0.85rem;
    padding: 1rem;
    background: color-mix(in srgb, var(--ng-bg, #08111f) 46%, transparent);
}

.admin-plan-socio-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.admin-plan-socio-kicker {
    color: var(--ng-accent, #00d4ff);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.admin-plan-socio-head h6 {
    color: var(--ng-heading, #f8fafc);
    font-size: 1.05rem;
    font-weight: 800;
    margin: 0;
}

.admin-plan-progress {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.45rem 0.7rem;
    border-radius: 0.65rem;
    background: color-mix(in srgb, var(--ng-surface-alt, #17233a) 85%, transparent);
}

.admin-plan-progress strong {
    color: #6ee78f;
    font-size: 1.25rem;
}

.admin-plan-progress span {
    color: var(--ng-text-muted, #b7c6d8);
    font-size: 0.86rem;
}

.admin-plan-exercise {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 0.75rem;
    align-items: start;
    background: color-mix(in srgb, var(--ng-bg, #08111f) 62%, transparent);
    border-radius: 0.6rem;
    padding: 0.7rem;
}

.admin-plan-exercise-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.admin-plan-followup-date {
    display: block;
    margin-top: 0.5rem;
    color: #6ee78f;
}

.admin-plan-exercise img {
    width: 88px;
    height: 66px;
    object-fit: cover;
    border-radius: 0.45rem;
}

@media (max-width: 576px) {
    .admin-plan-exercise {
        grid-template-columns: 1fr;
    }

    .admin-plan-exercise img {
        width: 100%;
        height: 150px;
    }
}

/* Ajuste de contraste para pantallas de profesor y consulta ADMIN segun estilo activo */
html[data-fusion-theme] {
    --fusion-heading: var(--fusion-title);
    --fusion-text-muted: var(--fusion-subtitle);
    --fusion-card-bg: color-mix(in srgb, var(--fusion-surface) 92%, var(--fusion-primary) 8%);
    --fusion-card-border: color-mix(in srgb, var(--fusion-accent) 42%, transparent);
    --fusion-input-bg: var(--fusion-surface);
    --fusion-input-border: color-mix(in srgb, var(--fusion-primary) 32%, transparent);
    --fusion-modal-bg: color-mix(in srgb, var(--fusion-surface) 94%, var(--fusion-primary) 6%);
}

html[data-fusion-theme] body.profesor-page,
html[data-fusion-theme] body.admin-teacher-plans-page {
    background-color: var(--fusion-bg);
    color: var(--fusion-text);
}

html[data-fusion-theme] .profesor-hero,
html[data-fusion-theme] .profesor-action-card,
html[data-fusion-theme] .profesor-form-card,
html[data-fusion-theme] .profesor-list-card,
html[data-fusion-theme] .profesor-dashboard,
html[data-fusion-theme] .profesor-dashboard-card,
html[data-fusion-theme] .profesor-stat-card,
html[data-fusion-theme] .profesor-subpanel,
html[data-fusion-theme] .profesor-day-card,
html[data-fusion-theme] .profesor-plan-card,
html[data-fusion-theme] .profesor-day-detail,
html[data-fusion-theme] .profesor-followup-socio,
html[data-fusion-theme] .admin-plan-detail-modal,
html[data-fusion-theme] .admin-plan-socio,
html[data-fusion-theme] .admin-plan-day {
    background: var(--fusion-card-bg);
    color: var(--fusion-text);
    border-color: var(--fusion-card-border);
    box-shadow: var(--fusion-shadow);
}

html[data-fusion-theme] .profesor-hero {
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--fusion-secondary) 16%, transparent),
            color-mix(in srgb, var(--fusion-accent) 10%, transparent)),
        var(--fusion-card-bg);
}

html[data-fusion-theme] .profesor-card-warning {
    background:
        linear-gradient(135deg, rgba(255, 209, 102, 0.16), color-mix(in srgb, var(--fusion-accent) 7%, transparent)),
        var(--fusion-card-bg);
}

html[data-fusion-theme] .profesor-progress-item,
html[data-fusion-theme] .profesor-recent-item,
html[data-fusion-theme] .profesor-expiring-item,
html[data-fusion-theme] .profesor-history-table-wrapper,
html[data-fusion-theme] .profesor-socio-chip,
html[data-fusion-theme] .profesor-week-builder,
html[data-fusion-theme] .profesor-week-day,
html[data-fusion-theme] .profesor-plan-calendar-day,
html[data-fusion-theme] .profesor-exercise-row,
html[data-fusion-theme] .profesor-detail-exercise,
html[data-fusion-theme] .profesor-followup-day,
html[data-fusion-theme] .profesor-followup-exercise,
html[data-fusion-theme] .admin-plan-detail-meta span,
html[data-fusion-theme] .admin-plan-observations,
html[data-fusion-theme] .admin-plan-progress,
html[data-fusion-theme] .admin-plan-exercise {
    background: color-mix(in srgb, var(--fusion-surface) 86%, var(--fusion-primary) 14%);
    color: var(--fusion-text);
    border-color: color-mix(in srgb, var(--fusion-primary) 18%, transparent);
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-0,
html[data-fusion-theme] .profesor-plan-calendar-day.tone-1,
html[data-fusion-theme] .profesor-plan-calendar-day.tone-2,
html[data-fusion-theme] .profesor-plan-calendar-day.tone-3,
html[data-fusion-theme] .profesor-plan-calendar-day.tone-4,
html[data-fusion-theme] .profesor-plan-calendar-day.tone-5 {
    color: var(--fusion-text);
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-0 {
    background: linear-gradient(135deg, color-mix(in srgb, #00d7ff 18%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-1 {
    background: linear-gradient(135deg, color-mix(in srgb, #7cff7a 18%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-2 {
    background: linear-gradient(135deg, color-mix(in srgb, #ffd166 20%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-3 {
    background: linear-gradient(135deg, color-mix(in srgb, #ff3fc5 16%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-4 {
    background: linear-gradient(135deg, color-mix(in srgb, #7896ff 18%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day.tone-5 {
    background: linear-gradient(135deg, color-mix(in srgb, #ff8040 18%, var(--fusion-surface)), var(--fusion-card-bg));
}

html[data-fusion-theme] .profesor-plan-calendar-day span,
html[data-fusion-theme] .profesor-plan-calendar-day small,
html[data-fusion-theme] .profesor-plan-calendar-day strong,
html[data-fusion-theme] .profesor-week-day span,
html[data-fusion-theme] .profesor-week-day small,
html[data-fusion-theme] .profesor-week-day strong {
    color: var(--fusion-text);
}

html[data-fusion-theme] .profesor-hero h2,
html[data-fusion-theme] .profesor-dashboard h3,
html[data-fusion-theme] .profesor-dashboard-card h4,
html[data-fusion-theme] .profesor-stat-card strong,
html[data-fusion-theme] .profesor-progress-head strong,
html[data-fusion-theme] .profesor-recent-item strong,
html[data-fusion-theme] .profesor-expiring-item strong,
html[data-fusion-theme] .profesor-form-card h3,
html[data-fusion-theme] .profesor-list-card h3,
html[data-fusion-theme] .profesor-subpanel h4,
html[data-fusion-theme] .profesor-day-detail h4,
html[data-fusion-theme] .profesor-plan-card h4,
html[data-fusion-theme] .profesor-followup-head h4,
html[data-fusion-theme] .profesor-followup-day h5,
html[data-fusion-theme] .profesor-followup-exercise-main strong,
html[data-fusion-theme] .admin-plan-day-head h6,
html[data-fusion-theme] .admin-plan-exercise h6,
html[data-fusion-theme] .admin-plan-socio-head h6 {
    color: var(--fusion-title);
}

html[data-fusion-theme] .profesor-hero p,
html[data-fusion-theme] .profesor-action-card strong,
html[data-fusion-theme] .profesor-stat-card span,
html[data-fusion-theme] .profesor-stat-card small,
html[data-fusion-theme] .profesor-progress-head small,
html[data-fusion-theme] .profesor-progress-meta,
html[data-fusion-theme] .profesor-recent-item small,
html[data-fusion-theme] .profesor-recent-item time,
html[data-fusion-theme] .profesor-recent-item p,
html[data-fusion-theme] .profesor-expiring-item small,
html[data-fusion-theme] .profesor-expiring-item time,
html[data-fusion-theme] .profesor-muted,
html[data-fusion-theme] .profesor-plan-card p,
html[data-fusion-theme] .profesor-followup-head small,
html[data-fusion-theme] .profesor-followup-day p,
html[data-fusion-theme] .profesor-followup-exercise small,
html[data-fusion-theme] .profesor-followup-note,
html[data-fusion-theme] .admin-plan-day-head small,
html[data-fusion-theme] .admin-plan-exercise small,
html[data-fusion-theme] .admin-plan-progress span {
    color: var(--fusion-subtitle);
}

html[data-fusion-theme] .profesor-plan-socios,
html[data-fusion-theme] .profesor-progress-socios,
html[data-fusion-theme] .profesor-plan-meta span,
html[data-fusion-theme] .profesor-followup-tags span,
html[data-fusion-theme] .plan-web-tags span {
    background: color-mix(in srgb, var(--fusion-secondary) 16%, var(--fusion-surface));
    color: var(--fusion-text);
    border-color: color-mix(in srgb, var(--fusion-secondary) 28%, transparent);
}

html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_wrapper,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_filter label,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_length label,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_info,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_wrapper,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_filter label,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_length label,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_info {
    color: var(--fusion-text);
}

html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_filter input,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_length select,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_filter input,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_length select {
    color: var(--fusion-text);
    background: var(--fusion-input-bg);
    border-color: var(--fusion-input-border);
}

html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable tbody tr,
html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable tbody tr > td,
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable tbody tr,
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable tbody tr > td {
    color: var(--fusion-text);
    background: var(--fusion-table-row-bg);
}

html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable tbody tr:nth-child(even),
html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable tbody tr:nth-child(even) > td,
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable tbody tr:nth-child(even),
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable tbody tr:nth-child(even) > td {
    background: var(--fusion-table-row-alt-bg);
}

html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable thead,
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable thead {
    background: var(--fusion-table-head-bg);
}

html[data-fusion-theme] .profesor-history-table-wrapper table.dataTable thead th,
html[data-fusion-theme] .admin-teacher-plans-page table.dataTable thead th {
    color: #ffffff;
}

@media (max-width: 767px) {
    .staff-calendar-panel {
        padding: 12px;
    }

    .staff-calendar-weekdays,
    .staff-calendar-grid {
        min-width: 720px;
        grid-template-columns: repeat(7, minmax(96px, 1fr));
        gap: 6px;
    }

    .staff-calendar-day {
        min-height: 132px;
        padding: 8px;
    }
}

@media (min-width: 768px) and (max-width: 1199px) {
    .staff-modal-content .dataTables_wrapper > .row:first-child {
        row-gap: 12px;
    }

    .staff-modal-content .dataTables_wrapper > .row:first-child > [class*="col-"] {
        flex: 0 0 100%;
        max-width: 100%;
        width: 100%;
    }

    .staff-modal-content .dataTables_length,
    .staff-modal-content .dataTables_filter {
        text-align: left !important;
    }

    .staff-modal-content .dataTables_filter label {
        display: flex;
        align-items: center;
        gap: 8px;
        width: 100%;
        margin-bottom: 0;
    }

    .staff-modal-content .dataTables_filter input {
        flex: 1 1 auto;
        width: 100% !important;
        max-width: none;
        margin-left: 0;
    }
}

.sidebar-product-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    min-height: 42px;
    padding: 8px 10px 12px;
    margin: 0 auto;
    text-align: center;
    color: #64748b;
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.78;
}

.sidebar-product-brand img {
    display: block;
    width: 116px;
    max-width: 100%;
    max-height: 30px;
    margin: 0 auto;
    height: auto;
    object-fit: contain;
}

.sidebar.collapsed .sidebar-product-brand {
    display: none;
}

html[data-fusion-theme] .sidebar-product-brand {
    color: color-mix(in srgb, var(--fusion-sidebar-text), transparent 24%);
}

/* ===============================
   PLANES PERSONALIZADOS USUARIO
================================ */
.personalized-plan-web-list {
    display: grid;
    gap: 22px;
}

.personalized-plan-web-card,
.plan-web-day,
.plan-web-exercise {
    border: 1px solid var(--fusion-card-border, rgba(0, 215, 255, 0.24));
    border-radius: 18px;
    background: var(--fusion-card-bg, rgba(9, 24, 50, 0.92));
    color: var(--fusion-text, #f7fbff);
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
}

.personalized-plan-web-card {
    display: grid;
    gap: 16px;
    padding: 22px;
}

.personalized-plan-web-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.personalized-plan-web-head h2,
.plan-web-day-title h3,
.plan-web-exercise h4 {
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.personalized-plan-web-head h2 {
    margin: 4px 0 0;
}

.plan-web-kicker {
    color: var(--fusion-accent, #00d7ff);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.plan-web-meta,
.plan-web-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.plan-web-meta span,
.plan-web-tags span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--fusion-secondary, #18b9ff), transparent 80%);
    color: var(--fusion-text, #f7fbff);
    font-size: 0.86rem;
    font-weight: 800;
}

.plan-web-days {
    display: grid;
    gap: 18px;
}

.plan-web-day {
    display: grid;
    gap: 14px;
    padding: 18px;
}

.plan-web-day-title {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.plan-web-day-title > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 64px;
    min-height: 36px;
    padding: 6px 12px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--fusion-primary, #00d7ff), var(--fusion-accent, #ff3fc5));
    color: #06111f;
    font-weight: 900;
}

.plan-web-exercises {
    display: grid;
    gap: 12px;
}

.plan-web-exercise {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 14px;
    padding: 14px;
}

.plan-web-exercise img {
    width: 120px;
    height: 96px;
    object-fit: cover;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.08);
}

.plan-web-exercise p,
.plan-web-observations,
.plan-web-note {
    color: var(--fusion-text-muted, #c9d8e8);
}

.plan-web-note {
    margin-top: 8px;
}

.plan-web-followup {
    display: grid;
    gap: 10px;
    margin-top: 16px;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary, #18b9ff), transparent 72%);
    border-radius: 14px;
    background: color-mix(in srgb, var(--fusion-surface, #122943), transparent 16%);
}

.plan-web-followup.done {
    border-color: color-mix(in srgb, #22c55e, transparent 45%);
    background: color-mix(in srgb, #22c55e, transparent 86%);
}

.plan-web-check {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: fit-content;
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.plan-web-check input {
    width: 18px;
    height: 18px;
    accent-color: #22c55e;
}

.plan-web-date {
    max-width: 240px;
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 800;
}

.plan-web-date input {
    margin-top: 6px;
}

.plan-web-followup textarea {
    min-height: 72px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--fusion-secondary, #18b9ff), transparent 62%);
    background: color-mix(in srgb, var(--fusion-bg, #071322), transparent 8%);
    color: var(--fusion-text, #f7fbff);
    padding: 10px 12px;
}

.plan-web-followup small {
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 800;
}

.plan-web-save-followup {
    justify-self: start;
    margin-top: 2px;
    font-weight: 800;
}

.plan-web-video-btn {
    margin-top: 16px;
}

@media (max-width: 767px) {
    .personalized-plan-web-head,
    .plan-web-day-title {
        grid-template-columns: 1fr;
        display: grid;
    }

    .plan-web-exercise {
        grid-template-columns: 1fr;
    }

    .plan-web-exercise img {
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }
}

/* ===============================
   PERFIL PROFESOR
================================ */
body.profesor-page .main-content {
    min-height: calc(100vh - 130px);
    padding-top: 90px;
}

.profesor-shell {
    animation: cyberFade 0.35s ease both;
}

.profesor-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 24px;
    border-radius: 18px;
    border: 1px solid rgba(0, 255, 190, 0.35);
    background:
        linear-gradient(135deg, rgba(0, 195, 255, 0.16), rgba(255, 63, 190, 0.12)),
        rgba(7, 18, 38, 0.84);
    color: var(--fusion-text, #f7fbff);
}

.profesor-hero h2 {
    margin: 6px 0 8px;
    color: var(--fusion-heading, #ffffff);
    font-weight: 800;
}

.profesor-hero p {
    max-width: 760px;
    margin: 0;
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-hero > i {
    font-size: 4rem;
    color: var(--fusion-accent, #00d7ff);
    text-shadow: 0 0 18px rgba(0, 215, 255, 0.45);
}

.profesor-kicker {
    color: var(--fusion-accent-alt, #ff3fc5);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.profesor-action-card,
.profesor-form-card,
.profesor-list-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 100%;
    padding: 22px;
    border-radius: 16px;
    color: var(--fusion-text, #f7fbff);
    text-decoration: none;
    background: var(--fusion-card-bg, rgba(9, 24, 50, 0.92));
    border: 1px solid var(--fusion-card-border, rgba(0, 215, 255, 0.24));
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.24);
}

.profesor-action-card i {
    width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: rgba(0, 215, 255, 0.16);
    color: var(--fusion-accent, #00d7ff);
    font-size: 1.5rem;
}

.profesor-action-card span,
.profesor-form-card h3,
.profesor-list-card h3 {
    color: var(--fusion-heading, #ffffff);
    font-weight: 800;
}

.profesor-action-card strong {
    color: var(--fusion-text-muted, #c9d8e8);
    font-size: 0.95rem;
}

.profesor-card-primary {
    border-color: rgba(0, 255, 190, 0.45);
}

.profesor-card-primary:hover {
    transform: translateY(-3px);
    filter: brightness(1.08);
}

.profesor-card-muted {
    opacity: 0.86;
}

.profesor-card-warning {
    border-color: rgba(255, 209, 102, 0.5);
    background:
        linear-gradient(135deg, rgba(255, 209, 102, 0.12), rgba(255, 63, 197, 0.08)),
        var(--fusion-card-bg, rgba(9, 24, 50, 0.92));
}

.profesor-card-warning i {
    color: #ffd166;
    background: rgba(255, 209, 102, 0.16);
}

.profesor-card-warning small {
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 800;
}

.profesor-dashboard {
    padding: 22px;
    border-radius: 16px;
    color: var(--fusion-text, #f7fbff);
    background: var(--fusion-card-bg, rgba(9, 24, 50, 0.92));
    border: 1px solid var(--fusion-card-border, rgba(0, 215, 255, 0.24));
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.24);
}

.profesor-dashboard h3,
.profesor-dashboard-card h4 {
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.profesor-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.profesor-stat-card,
.profesor-dashboard-card {
    padding: 16px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(0, 215, 255, 0.2);
}

.profesor-stat-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 114px;
}

.profesor-stat-card span {
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 800;
}

.profesor-stat-card strong {
    color: var(--fusion-heading, #ffffff);
    font-size: 2rem;
    line-height: 1;
    font-weight: 900;
}

.profesor-stat-card small {
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-stat-highlight {
    border-color: rgba(124, 255, 122, 0.44);
    background: rgba(20, 184, 120, 0.16);
}

.profesor-dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    gap: 16px;
}

.profesor-dashboard-card h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    font-size: 1.05rem;
}

.profesor-dashboard-card h4 i {
    color: var(--fusion-accent, #00d7ff);
}

.profesor-progress-item,
.profesor-recent-item {
    padding: 13px;
    border-radius: 12px;
    background: rgba(3, 14, 31, 0.32);
    border: 1px solid rgba(255, 255, 255, 0.09);
}

.profesor-progress-item + .profesor-progress-item,
.profesor-recent-item + .profesor-recent-item {
    margin-top: 10px;
}

.profesor-progress-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.profesor-progress-head strong,
.profesor-recent-item strong {
    display: block;
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.profesor-progress-head small,
.profesor-progress-meta,
.profesor-recent-item small,
.profesor-recent-item time,
.profesor-recent-item p {
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-progress-head > span {
    flex: 0 0 auto;
    padding: 5px 10px;
    border-radius: 999px;
    color: #06111d;
    font-size: 0.82rem;
    font-weight: 900;
}

.profesor-progress-complete {
    background: #7cff7a;
}

.profesor-progress-active {
    background: #ffd166;
}

.profesor-progress-empty {
    background: #94a3b8;
}

.profesor-progress-meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-top: 6px;
    font-size: 0.85rem;
    font-weight: 700;
}

.profesor-progress-detail {
    margin-top: 10px;
    width: 100%;
    justify-content: center;
    font-weight: 900;
}

.profesor-progress-socios {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    margin: 10px 0;
    padding: 9px 11px;
    border-radius: 11px;
    background: rgba(0, 215, 255, 0.1);
    border: 1px solid rgba(0, 215, 255, 0.2);
    color: var(--fusion-text, #f7fbff);
}

.profesor-progress-socios i {
    color: var(--fusion-accent, #00d7ff);
    margin-top: 2px;
}

.profesor-progress-socios strong {
    color: var(--fusion-heading, #ffffff);
    white-space: nowrap;
}

.profesor-progress-socios span {
    color: var(--fusion-text, #f7fbff);
    font-weight: 800;
}

.profesor-recent-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 12px;
}

.profesor-recent-item span {
    display: block;
    color: var(--fusion-text, #f7fbff);
    font-weight: 800;
}

.profesor-recent-item time {
    white-space: nowrap;
    font-size: 0.82rem;
    font-weight: 800;
}

.profesor-recent-item p {
    grid-column: 1 / -1;
    margin: 0;
    padding-top: 6px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.profesor-empty-compact {
    min-height: 130px;
}

.profesor-expiring-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 10px;
}

.profesor-expiring-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 6px 12px;
    align-items: center;
    padding: 13px;
    border-radius: 12px;
    background: rgba(255, 209, 102, 0.1);
    border: 1px solid rgba(255, 209, 102, 0.28);
}

.profesor-expiring-item strong {
    display: block;
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.profesor-expiring-item small,
.profesor-expiring-item time {
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 700;
}

.profesor-expiring-item > span {
    padding: 5px 9px;
    border-radius: 999px;
    color: #06111d;
    background: #ffd166;
    font-size: 0.8rem;
    font-weight: 900;
}

.profesor-expiring-item time {
    grid-column: 1 / -1;
    font-size: 0.84rem;
}

.profesor-expiring-socios {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 8px;
    color: var(--fusion-text, #e8f4ff);
    font-size: 0.86rem;
    font-weight: 800;
}

.profesor-expiring-socios i {
    color: var(--fusion-primary, #00d4ff);
}

.profesor-expiring-renew {
    grid-column: 1 / -1;
    justify-self: start;
    margin-top: 4px;
    font-weight: 900;
}

.profesor-history-card {
    overflow: hidden;
}

.profesor-history-table-wrapper {
    padding: 6px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(0, 212, 255, 0.16);
}

.profesor-history-table-wrapper .dataTables_wrapper,
.profesor-history-table-wrapper .dataTables_filter label,
.profesor-history-table-wrapper .dataTables_length label,
.profesor-history-table-wrapper .dataTables_info {
    color: var(--fusion-text, #e8f4ff);
}

.profesor-history-table-wrapper .dataTables_filter input,
.profesor-history-table-wrapper .dataTables_length select {
    color: var(--fusion-text, #e8f4ff);
    background: var(--fusion-input-bg, rgba(4, 16, 31, 0.86));
    border: 1px solid var(--fusion-input-border, rgba(0, 212, 255, 0.28));
}

.profesor-history-table-wrapper table.dataTable thead {
    background: linear-gradient(90deg, rgba(0, 212, 255, 0.28), rgba(255, 75, 216, 0.22));
}

.profesor-history-table-wrapper table.dataTable thead th,
.profesor-history-table-wrapper table.dataTable tbody td {
    text-align: left;
    vertical-align: middle;
}

.profesor-history-table-wrapper table.dataTable tbody tr,
.profesor-history-table-wrapper table.dataTable tbody tr > td {
    color: var(--fusion-text, #e8f4ff);
    background: rgba(255, 255, 255, 0.03);
}

.profesor-plans-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(300px, 0.8fr);
    gap: 22px;
}

.profesor-muted {
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-flow {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.profesor-flow li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: var(--fusion-text, #f7fbff);
}

.profesor-flow span {
    flex: 0 0 30px;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: #05111e;
    font-weight: 900;
    background: linear-gradient(135deg, #00d7ff, #7cff7a);
}

.profesor-subpanel,
.profesor-day-card,
.profesor-plan-card,
.profesor-day-detail {
    padding: 18px;
    border-radius: 14px;
    border: 1px solid rgba(0, 215, 255, 0.24);
    background: rgba(4, 15, 34, 0.42);
}

.profesor-subpanel h4,
.profesor-day-detail h4 {
    color: var(--fusion-heading, #ffffff);
    font-size: 1.05rem;
    font-weight: 800;
}

.profesor-socios-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 10px;
    max-height: 260px;
    overflow: auto;
    padding-right: 4px;
}

.profesor-socio-chip {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 74px;
    padding: 12px;
    border: 1px solid rgba(0, 215, 255, 0.28);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--fusion-text, #f7fbff);
    text-align: left;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.profesor-socio-chip span {
    font-weight: 800;
}

.profesor-socio-chip small {
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-socio-chip.active {
    border-color: rgba(124, 255, 122, 0.8);
    background: rgba(20, 184, 120, 0.24);
}

.profesor-socio-chip:hover {
    transform: translateY(-2px);
}

.profesor-day-card + .profesor-day-card {
    margin-top: 16px;
}

.profesor-week-builder {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 18px;
    padding: 16px;
    border-radius: 14px;
    background: rgba(0, 215, 255, 0.08);
    border: 1px solid rgba(0, 215, 255, 0.2);
}

.profesor-week-builder h5 {
    margin: 0 0 4px;
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.profesor-week-calendar {
    display: grid;
    grid-template-columns: repeat(7, minmax(82px, 1fr));
    gap: 9px;
}

.profesor-week-day {
    min-height: 92px;
    padding: 10px 8px;
    border: 1px solid rgba(0, 215, 255, 0.24);
    border-radius: 12px;
    color: var(--fusion-text, #f7fbff);
    background: rgba(255, 255, 255, 0.06);
    text-align: center;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.profesor-week-day span,
.profesor-week-day small {
    display: block;
    color: var(--fusion-text-muted, #c9d8e8);
    font-weight: 800;
}

.profesor-week-day strong {
    display: block;
    color: var(--fusion-heading, #ffffff);
    font-size: 1.65rem;
    line-height: 1.1;
    margin: 4px 0;
}

.profesor-week-day.active {
    border-color: rgba(124, 255, 122, 0.7);
    background: linear-gradient(135deg, rgba(20, 184, 120, 0.28), rgba(0, 215, 255, 0.16));
    box-shadow: 0 0 18px rgba(0, 215, 255, 0.14);
}

.profesor-week-day:hover {
    transform: translateY(-2px);
}

.profesor-week-badge {
    flex: 0 0 auto;
    padding: 3px 7px;
    border-radius: 999px;
    color: #06111d;
    background: var(--fusion-accent, #00d7ff);
    font-size: 0.72rem;
    font-weight: 900;
    line-height: 1.1;
}

.profesor-plan-calendar {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
    margin: 16px 0;
}

.profesor-plan-calendar-day {
    min-height: 98px;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--fusion-text, #f7fbff);
    text-align: left;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.profesor-plan-calendar-day span,
.profesor-plan-calendar-day small {
    display: block;
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.78rem;
    font-weight: 800;
}

.profesor-plan-calendar-day strong {
    display: block;
    margin: 5px 0;
    color: #ffffff;
    font-size: 1rem;
    font-weight: 900;
}

.profesor-plan-calendar-day:hover {
    transform: translateY(-2px);
    filter: brightness(1.08);
}

.profesor-plan-calendar-day.selected {
    border-color: #ffffff;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.16), 0 0 24px rgba(0, 215, 255, 0.18);
}

.profesor-plan-calendar-day.empty {
    opacity: 0.78;
}

.profesor-plan-calendar-day.has-exercises {
    opacity: 1;
}

.profesor-plan-calendar-day.tone-0 {
    background: linear-gradient(135deg, rgba(0, 215, 255, 0.28), rgba(7, 19, 34, 0.72));
}

.profesor-plan-calendar-day.tone-1 {
    background: linear-gradient(135deg, rgba(124, 255, 122, 0.24), rgba(7, 19, 34, 0.72));
}

.profesor-plan-calendar-day.tone-2 {
    background: linear-gradient(135deg, rgba(255, 209, 102, 0.26), rgba(7, 19, 34, 0.72));
}

.profesor-plan-calendar-day.tone-3 {
    background: linear-gradient(135deg, rgba(255, 63, 197, 0.24), rgba(7, 19, 34, 0.72));
}

.profesor-plan-calendar-day.tone-4 {
    background: linear-gradient(135deg, rgba(120, 150, 255, 0.28), rgba(7, 19, 34, 0.72));
}

.profesor-plan-calendar-day.tone-5 {
    background: linear-gradient(135deg, rgba(255, 128, 64, 0.24), rgba(7, 19, 34, 0.72));
}

.profesor-day-card-active {
    border-color: rgba(255, 255, 255, 0.22);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22);
}

.profesor-exercise-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.profesor-exercise-row {
    padding: 14px;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.profesor-exercise-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    color: var(--fusion-heading, #ffffff);
}

.profesor-form-actions,
.profesor-plan-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.profesor-plan-card + .profesor-plan-card {
    margin-top: 14px;
}

.profesor-plan-card h4 {
    color: var(--fusion-heading, #ffffff);
    font-size: 1.05rem;
    font-weight: 900;
    margin-bottom: 4px;
}

.profesor-plan-card p {
    color: var(--fusion-text-muted, #c9d8e8);
    margin-bottom: 0;
}

.profesor-plan-socios {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--fusion-text, #f7fbff);
    background: rgba(0, 215, 255, 0.1);
    border: 1px solid rgba(0, 215, 255, 0.22);
    line-height: 1.35;
}

.profesor-plan-socios i {
    color: var(--fusion-accent, #00d7ff);
    margin-top: 2px;
}

.profesor-plan-socios strong {
    color: var(--fusion-heading, #ffffff);
    white-space: nowrap;
}

.profesor-plan-socios span {
    color: var(--fusion-text, #f7fbff);
    font-weight: 800;
}

.profesor-plan-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 12px 0;
}

.profesor-plan-meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(0, 215, 255, 0.13);
    color: var(--fusion-text, #f7fbff);
    font-size: 0.85rem;
}

.profesor-empty {
    display: grid;
    place-items: center;
    gap: 10px;
    min-height: 180px;
    color: var(--fusion-text-muted, #c9d8e8);
    border: 1px dashed rgba(0, 215, 255, 0.34);
    border-radius: 14px;
}

.profesor-empty i {
    color: var(--fusion-accent, #00d7ff);
    font-size: 2rem;
}

.profesor-modal {
    background: var(--fusion-modal-bg, var(--fusion-card-bg, #24324f));
    color: var(--fusion-text, #f7fbff);
}

.profesor-modal .modal-header {
    border-color: rgba(255, 255, 255, 0.16);
}

.profesor-detail-exercise {
    display: grid;
    grid-template-columns: minmax(180px, 1.4fr) repeat(4, minmax(90px, 0.7fr));
    gap: 8px;
    align-items: center;
    padding: 12px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.06);
}

.profesor-detail-exercise + .profesor-detail-exercise {
    margin-top: 8px;
}

.profesor-detail-exercise strong {
    color: var(--fusion-heading, #ffffff);
}

.profesor-detail-exercise small {
    grid-column: 1 / -1;
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-followup-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.profesor-followup-socio {
    padding: 18px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(0, 215, 255, 0.24);
}

.profesor-followup-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 12px;
}

.profesor-followup-head h4 {
    margin: 0 0 3px;
    color: var(--fusion-heading, #ffffff);
    font-size: 1.1rem;
    font-weight: 900;
}

.profesor-followup-head small,
.profesor-followup-day p,
.profesor-followup-exercise small,
.profesor-followup-note {
    color: var(--fusion-text-muted, #c9d8e8);
}

.profesor-followup-progress {
    height: 10px;
    margin-bottom: 16px;
    background: rgba(255, 255, 255, 0.11);
}

.profesor-followup-progress .progress-bar {
    background: linear-gradient(90deg, var(--fusion-accent, #00d7ff), var(--fusion-accent-alt, #ff3fc5));
}

.profesor-followup-day {
    padding: 14px;
    border-radius: 14px;
    background: rgba(3, 14, 31, 0.32);
    border: 1px solid rgba(255, 255, 255, 0.09);
}

.profesor-followup-day + .profesor-followup-day {
    margin-top: 12px;
}

.profesor-followup-day h5 {
    margin: 0 0 6px;
    color: var(--fusion-heading, #ffffff);
    font-size: 1rem;
    font-weight: 900;
}

.profesor-followup-exercise {
    padding: 12px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.09);
}

.profesor-followup-exercise + .profesor-followup-exercise {
    margin-top: 10px;
}

.profesor-followup-exercise.completed {
    border-color: rgba(124, 255, 122, 0.45);
    background: rgba(20, 184, 120, 0.12);
}

.profesor-followup-exercise-main {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.profesor-followup-exercise-main strong {
    display: block;
    color: var(--fusion-heading, #ffffff);
    font-weight: 900;
}

.profesor-followup-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 10px;
}

.profesor-followup-tags span {
    padding: 5px 9px;
    border-radius: 999px;
    color: var(--fusion-text, #f7fbff);
    background: rgba(0, 215, 255, 0.13);
    font-size: 0.82rem;
    font-weight: 700;
}

.profesor-followup-note {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.88rem;
}

.profesor-followup-note i {
    color: var(--fusion-accent, #00d7ff);
    margin-right: 5px;
}

@media (max-width: 991px) {
    .profesor-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .profesor-plans-grid {
        grid-template-columns: 1fr;
    }

    .profesor-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .profesor-week-calendar {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .profesor-detail-exercise {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 767px) {
    .profesor-hero {
        align-items: flex-start;
    }

    .profesor-hero > i {
        display: none;
    }

    .profesor-socios-list {
        grid-template-columns: 1fr;
    }

    .profesor-stats-grid,
    .profesor-plans-grid {
        grid-template-columns: 1fr;
    }

    .profesor-week-calendar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .profesor-detail-exercise {
        grid-template-columns: 1fr;
    }

    .profesor-followup-head,
    .profesor-followup-exercise-main {
        flex-direction: column;
    }
}

.products-page .product-summary-card,
.products-page .product-admin-card {
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.18), rgba(34, 197, 94, 0.14));
    border: 1px solid rgba(34, 197, 94, 0.28);
    color: var(--fusion-text, #eef6fb);
    box-shadow: 0 18px 42px rgba(7, 19, 34, 0.18);
}

.products-page .product-summary-warning {
    border-color: rgba(245, 158, 11, 0.45);
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.2), rgba(14, 165, 233, 0.12));
}

.products-page .product-summary-button {
    appearance: none;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.products-page .product-summary-button:hover {
    transform: translateY(-2px);
    border-color: rgba(245, 158, 11, 0.8);
    box-shadow: 0 18px 38px rgba(245, 158, 11, 0.16);
}

.products-page .product-summary-income,
.products-page .product-sale-card {
    border-color: rgba(34, 197, 94, 0.42);
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2), rgba(14, 165, 233, 0.12));
}

.products-page .product-summary-outcome,
.products-page .product-purchase-card {
    border-color: rgba(248, 113, 113, 0.42);
    background: linear-gradient(135deg, rgba(248, 113, 113, 0.19), rgba(14, 165, 233, 0.12));
}

.products-page .product-category-card {
    border-color: rgba(168, 85, 247, 0.36);
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.18), rgba(14, 165, 233, 0.12));
}

.products-page .product-low-stock-card {
    border-color: rgba(245, 158, 11, 0.56);
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(239, 68, 68, 0.12));
}

.products-page .product-low-stock-card p {
    color: var(--fusion-muted, #a9bed0);
}

.products-page .low-stock-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}

.products-page .low-stock-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 12px 14px;
    border: 1px solid rgba(245, 158, 11, 0.42);
    border-radius: 14px;
    background: rgba(7, 19, 34, 0.22);
    color: var(--fusion-text, #eef6fb);
    text-align: left;
}

.products-page .low-stock-item span {
    font-weight: 900;
}

.products-page .low-stock-item strong {
    color: #facc15;
    font-size: 0.88rem;
}

.products-page .product-summary-card h6,
.products-page .product-admin-card .form-label {
    color: var(--fusion-muted, #a9bed0);
    font-weight: 800;
}

.products-page .product-summary-card h3,
.products-page .product-admin-card h3 {
    color: var(--fusion-title, #17d8ff);
    font-weight: 900;
}

.products-page .products-tabs .nav-link.active {
    color: #04131d;
    background: linear-gradient(135deg, #22c55e, #38bdf8);
}

.products-page .product-thumb {
    width: 58px;
    height: 44px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid rgba(56, 189, 248, 0.35);
    box-shadow: 0 10px 22px rgba(7, 19, 34, 0.18);
}

.products-page .product-image-preview {
    width: min(100%, 280px);
    padding: 8px;
    border: 1px solid rgba(56, 189, 248, 0.28);
    border-radius: 16px;
    background: rgba(7, 19, 34, 0.16);
}

.products-page .product-image-preview img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 12px;
    display: block;
}

.products-page .product-admin-card {
    max-width: 100%;
    overflow: hidden;
}

.products-page .product-admin-card .form-control,
.products-page .product-admin-card .form-select {
    min-width: 0;
}

.products-page .products-tabs {
    flex-wrap: wrap;
    gap: 8px;
}

.products-page .products-tabs .nav-link {
    white-space: nowrap;
}

.products-page .table-wrapper-cyber {
    max-width: 100%;
    overflow-x: auto;
}

.app-access-card {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    align-items: center;
    padding: 24px;
    border-radius: 20px;
    border: 1px solid rgba(0, 209, 255, 0.26);
    background:
        radial-gradient(circle at top right, rgba(0, 209, 255, 0.18), transparent 18rem),
        linear-gradient(135deg, #0a3d62, #10243d);
    color: #ffffff;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
}

.app-access-card-profesor {
    background:
        radial-gradient(circle at top right, rgba(46, 226, 167, 0.2), transparent 18rem),
        linear-gradient(135deg, #11331f, #10243d);
}

.app-access-content span {
    display: inline-flex;
    margin-bottom: 8px;
    color: #63f7ff;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.app-access-content h2 {
    margin: 0 0 10px;
    color: #ffffff;
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 900;
}

.app-access-content p {
    max-width: 760px;
    margin: 0 0 18px;
    color: rgba(255, 255, 255, 0.82);
    line-height: 1.55;
}

.btn-app-access {
    border: 0;
    border-radius: 999px;
    padding: 10px 18px;
    color: #071322;
    background: linear-gradient(135deg, #63f7ff, #40f2a6);
    font-weight: 900;
}

.btn-app-access:hover {
    color: #071322;
    filter: brightness(1.04);
}

.app-access-qr {
    width: 190px;
    display: grid;
    gap: 8px;
    justify-items: center;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.95);
    color: #0a3d62;
    text-align: center;
    font-weight: 800;
}

.app-access-qr img {
    width: 166px;
    height: 166px;
    display: block;
}

.app-access-qr small {
    color: #0a3d62;
    line-height: 1.2;
}

@media (min-width: 768px) and (max-width: 1199px) {
    .products-page .container-cyberpunk {
        padding: 22px;
    }

    .products-page .product-admin-card {
        padding: 18px !important;
    }

    .products-page .product-admin-card .form-switch {
        margin-top: 0 !important;
        min-height: 48px;
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .products-page .dataTables_wrapper > .row:first-child {
        row-gap: 12px;
    }

    .products-page .dataTables_wrapper > .row:first-child > [class*="col-"] {
        flex: 0 0 100%;
        max-width: 100%;
        width: 100%;
    }

    .products-page .dataTables_length,
    .products-page .dataTables_filter {
        text-align: left !important;
    }

    .products-page .dataTables_filter label {
        display: flex;
        align-items: center;
        gap: 8px;
        width: 100%;
        margin-bottom: 0;
    }

    .products-page .dataTables_filter input {
        flex: 1 1 auto;
        width: 100% !important;
        max-width: none;
        margin-left: 0;
    }
}

@media (max-width: 768px) {
    .app-access-card {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .app-access-qr {
        margin: 0 auto;
    }
}

/* Refuerzo final: pantallas de profesor/planes siempre respetan el estilo activo */
html[data-fusion-theme] body.profesor-page,
html[data-fusion-theme] body.admin-teacher-plans-page {
    background-color: var(--fusion-bg) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] body.profesor-page .container-cyberpunk,
html[data-fusion-theme] body.admin-teacher-plans-page .container-cyberpunk,
html[data-fusion-theme] .profesor-hero,
html[data-fusion-theme] .profesor-action-card,
html[data-fusion-theme] .profesor-form-card,
html[data-fusion-theme] .profesor-list-card,
html[data-fusion-theme] .profesor-dashboard,
html[data-fusion-theme] .profesor-dashboard-card,
html[data-fusion-theme] .profesor-stat-card,
html[data-fusion-theme] .app-access-card,
html[data-fusion-theme] .profesor-subpanel,
html[data-fusion-theme] .profesor-day-card,
html[data-fusion-theme] .profesor-plan-card,
html[data-fusion-theme] .profesor-day-detail,
html[data-fusion-theme] .profesor-followup-socio,
html[data-fusion-theme] .admin-plan-detail-modal,
html[data-fusion-theme] .admin-plan-socio,
html[data-fusion-theme] .admin-plan-day,
html[data-fusion-theme] .admin-plans-card {
    background: color-mix(in srgb, var(--fusion-surface) 94%, var(--fusion-primary) 6%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-accent) 36%, transparent) !important;
}

html[data-fusion-theme] .profesor-progress-item,
html[data-fusion-theme] .profesor-recent-item,
html[data-fusion-theme] .profesor-expiring-item,
html[data-fusion-theme] .profesor-history-table-wrapper,
html[data-fusion-theme] .profesor-socio-chip,
html[data-fusion-theme] .profesor-week-builder,
html[data-fusion-theme] .profesor-week-day,
html[data-fusion-theme] .profesor-plan-calendar-day,
html[data-fusion-theme] .profesor-exercise-row,
html[data-fusion-theme] .profesor-detail-exercise,
html[data-fusion-theme] .profesor-followup-day,
html[data-fusion-theme] .profesor-followup-exercise,
html[data-fusion-theme] .admin-plan-detail-meta span,
html[data-fusion-theme] .admin-plan-observations,
html[data-fusion-theme] .admin-plan-progress,
html[data-fusion-theme] .admin-plan-exercise {
    background: color-mix(in srgb, var(--fusion-surface) 88%, var(--fusion-primary) 12%) !important;
    color: var(--fusion-text) !important;
    border-color: color-mix(in srgb, var(--fusion-primary) 20%, transparent) !important;
}

html[data-fusion-theme] .profesor-hero h2,
html[data-fusion-theme] .profesor-dashboard h3,
html[data-fusion-theme] .profesor-dashboard-card h4,
html[data-fusion-theme] .profesor-stat-card strong,
html[data-fusion-theme] .profesor-progress-head strong,
html[data-fusion-theme] .profesor-recent-item strong,
html[data-fusion-theme] .profesor-expiring-item strong,
html[data-fusion-theme] .profesor-form-card h3,
html[data-fusion-theme] .profesor-list-card h3,
html[data-fusion-theme] .profesor-subpanel h4,
html[data-fusion-theme] .profesor-day-detail h4,
html[data-fusion-theme] .profesor-plan-card h4,
html[data-fusion-theme] .profesor-followup-head h4,
html[data-fusion-theme] .profesor-followup-day h5,
html[data-fusion-theme] .profesor-followup-exercise-main strong,
html[data-fusion-theme] .profesor-plan-calendar-day strong,
html[data-fusion-theme] .profesor-week-day strong,
html[data-fusion-theme] .admin-plan-day-head h6,
html[data-fusion-theme] .admin-plan-exercise h6,
html[data-fusion-theme] .admin-plan-socio-head h6 {
    color: var(--fusion-title) !important;
}

html[data-fusion-theme] .profesor-hero p,
html[data-fusion-theme] .profesor-action-card strong,
html[data-fusion-theme] .profesor-stat-card span,
html[data-fusion-theme] .profesor-stat-card small,
html[data-fusion-theme] .profesor-progress-head small,
html[data-fusion-theme] .profesor-progress-meta,
html[data-fusion-theme] .profesor-recent-item small,
html[data-fusion-theme] .profesor-recent-item time,
html[data-fusion-theme] .profesor-recent-item p,
html[data-fusion-theme] .profesor-expiring-item small,
html[data-fusion-theme] .profesor-expiring-item time,
html[data-fusion-theme] .profesor-muted,
html[data-fusion-theme] .profesor-plan-card p,
html[data-fusion-theme] .profesor-followup-head small,
html[data-fusion-theme] .profesor-followup-day p,
html[data-fusion-theme] .profesor-followup-exercise small,
html[data-fusion-theme] .profesor-followup-note,
html[data-fusion-theme] .profesor-plan-calendar-day span,
html[data-fusion-theme] .profesor-plan-calendar-day small,
html[data-fusion-theme] .profesor-week-day span,
html[data-fusion-theme] .profesor-week-day small,
html[data-fusion-theme] .admin-plan-day-head small,
html[data-fusion-theme] .admin-plan-exercise small,
html[data-fusion-theme] .admin-plan-progress span {
    color: var(--fusion-subtitle) !important;
}

html[data-fusion-theme] .profesor-plan-socios,
html[data-fusion-theme] .profesor-progress-socios,
html[data-fusion-theme] .profesor-plan-meta span,
html[data-fusion-theme] .profesor-followup-tags span,
html[data-fusion-theme] .plan-web-tags span {
    background: color-mix(in srgb, var(--fusion-secondary) 16%, var(--fusion-surface)) !important;
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_wrapper,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_filter label,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_length label,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_info,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_wrapper,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_filter label,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_length label,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_info {
    color: var(--fusion-text) !important;
}

html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_filter input,
html[data-fusion-theme] .profesor-history-table-wrapper .dataTables_length select,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_filter input,
html[data-fusion-theme] .admin-teacher-plans-page .dataTables_length select {
    color: var(--fusion-text) !important;
    background: var(--fusion-surface) !important;
    border-color: color-mix(in srgb, var(--fusion-primary) 32%, transparent) !important;
}

html[data-fusion-theme] .app-access-card {
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--fusion-secondary) 18%, transparent), transparent 18rem),
        linear-gradient(135deg, var(--fusion-primary), color-mix(in srgb, var(--fusion-surface), #000 28%)) !important;
}

html[data-fusion-theme] .app-access-content h2,
html[data-fusion-theme] .app-access-content span {
    color: #ffffff !important;
}

html[data-fusion-theme] .app-access-content p {
    color: rgba(255, 255, 255, 0.84) !important;
}
