/* =============================================================
   CALENDARIO FCA - CSS PROFESSIONAL PLUS
   Versión: 4.6.3
   ============================================================= */

/* =============================================================
   VARIABLES CSS
   ============================================================= */

.cfca-container,
.cfca-public-scope,
.cfca-admin-scope,
[data-cfca-scope="public"],
[data-cfca-scope="admin"] {
    --cfca-primary: #2e7d32;
    --cfca-primary-light: #4caf50;
    --cfca-primary-dark: #1b5e20;
    --cfca-secondary: #1976d2;
    --cfca-accent: #c6a43f;
    --cfca-fide: #6a1b9a;
    --cfca-fecodaz: #c6a43f;
    --cfca-success: #28a745;
    --cfca-danger: #dc3545;
    --cfca-warning: #ffc107;
    --cfca-info: #17a2b8;
    --cfca-light: #f8f9fa;
    --cfca-dark: #343a40;
    --cfca-gray: #6c757d;
    --cfca-gray-light: #e9ecef;
    --cfca-border: #dee2e6;
    --cfca-border-radius: 12px;
    --cfca-border-radius-sm: 8px;
    --cfca-border-radius-lg: 20px;
    --cfca-border-radius-xl: 40px;
    --cfca-box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    --cfca-box-shadow-hover: 0 15px 40px rgba(46,125,50,0.15);
    --cfca-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --cfca-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* =============================================================
   CONTENEDOR PRINCIPAL
   ============================================================= */
.cfca-container {
    max-width: 1400px;
    margin: 30px auto;
    font-family: var(--cfca-font-family);
    color: var(--cfca-dark);
    position: relative;
    z-index: 1;
}

/* =============================================================
   SELECTOR DE VISTAS (TABLA / TARJETAS / CALENDARIO / AGENDA)
   ============================================================= */
.cfca-view-selector {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    background: white;
    padding: 8px;
    border-radius: var(--cfca-border-radius-xl);
    box-shadow: var(--cfca-box-shadow);
    margin-bottom: 30px;
    border: 1px solid var(--cfca-gray-light);
    position: relative;
    z-index: 10;
}

.cfca-view-btn {
    padding: 12px 24px;
    border: none;
    border-radius: var(--cfca-border-radius-xl);
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95rem;
    transition: var(--cfca-transition);
    background: white;
    color: var(--cfca-primary);
    border: 2px solid transparent;
    letter-spacing: 0.5px;
    position: relative;
    overflow: hidden;
}

.cfca-view-btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(46, 125, 50, 0.1);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
    z-index: -1;
}

.cfca-view-btn:hover::before {
    width: 300px;
    height: 300px;
}

.cfca-view-btn:hover {
    transform: translateY(-2px);
    border-color: var(--cfca-primary-light);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.15);
}

.cfca-view-btn.active {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    box-shadow: 0 8px 20px rgba(46, 125, 50, 0.3);
    transform: scale(1.05);
}

.cfca-view-btn.active:hover {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 12px 25px rgba(46, 125, 50, 0.4);
}

/* Botones de exportación */
.cfca-view-selector .cfca-btn-secondary {
    margin-left: 10px;
    padding: 12px 24px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    color: var(--cfca-primary);
    border: 2px solid var(--cfca-primary);
    font-weight: 600;
    transition: var(--cfca-transition);
}

.cfca-view-selector .cfca-btn-secondary:hover {
    background: var(--cfca-primary);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.3);
}

/* =============================================================
   FILTROS AVANZADOS
   ============================================================= */
.cfca-filters {
    background: linear-gradient(135deg, #ffffff 0%, #f8fdfa 100%);
    padding: 30px;
    border-radius: var(--cfca-border-radius-lg);
    margin-bottom: 30px;
    border: 2px solid var(--cfca-primary-light);
    box-shadow: var(--cfca-box-shadow);
    backdrop-filter: blur(10px);
}

.cfca-filter-group {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.cfca-search-wrapper {
    flex: 3;
    min-width: 280px;
    position: relative;
}

.cfca-search-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2rem;
    color: var(--cfca-primary);
    opacity: 0.6;
    transition: var(--cfca-transition);
    pointer-events: none;
    z-index: 2;
}

.cfca-search-input {
    width: 100%;
    padding: 16px 16px 16px 55px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-xl);
    font-size: 1rem;
    transition: var(--cfca-transition);
    background: white;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.02);
}

.cfca-search-input:focus {
    border-color: var(--cfca-primary);
    outline: none;
    box-shadow: 0 0 0 4px rgba(46, 125, 50, 0.1);
    transform: translateY(-1px);
}

.cfca-search-input:focus + .cfca-search-icon {
    color: var(--cfca-primary);
    opacity: 1;
    transform: translateY(-50%) scale(1.1);
}

.cfca-select {
    flex: 1;
    min-width: 150px;
    padding: 16px 20px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-xl);
    background: white;
    cursor: pointer;
    transition: var(--cfca-transition);
    font-size: 0.95rem;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232e7d32' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 16px;
    padding-right: 45px;
}

.cfca-select:hover {
    border-color: var(--cfca-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.1);
}

.cfca-select:focus {
    border-color: var(--cfca-primary);
    outline: none;
    box-shadow: 0 0 0 4px rgba(46, 125, 50, 0.1);
}

/* Botones principales */
.cfca-btn-primary {
    padding: 16px 32px;
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    border: none;
    border-radius: var(--cfca-border-radius-xl);
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95rem;
    transition: var(--cfca-transition);
    box-shadow: 0 4px 15px rgba(46, 125, 50, 0.3);
    position: relative;
    overflow: hidden;
}

.cfca-btn-primary::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.cfca-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(46, 125, 50, 0.4);
}

.cfca-btn-primary:hover::after {
    width: 300px;
    height: 300px;
}

.cfca-btn-primary:active {
    transform: translateY(0);
}

.cfca-btn-secondary {
    padding: 16px 32px;
    background: white;
    color: var(--cfca-primary);
    border: 2px solid var(--cfca-primary);
    border-radius: var(--cfca-border-radius-xl);
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95rem;
    transition: var(--cfca-transition);
}

.cfca-btn-secondary:hover {
    background: var(--cfca-primary);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.2);
}

/* Checkbox group */
.cfca-checkbox-group {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: center;
    margin-top: 20px;
    padding: 20px 0 0;
    border-top: 2px dashed var(--cfca-gray-light);
}

.cfca-checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    background: white;
    padding: 12px 24px;
    border-radius: var(--cfca-border-radius-xl);
    border: 2px solid var(--cfca-gray-light);
    transition: var(--cfca-transition);
    font-size: 0.95rem;
    user-select: none;
}

.cfca-checkbox-label:hover {
    border-color: var(--cfca-primary);
    background: linear-gradient(135deg, #ffffff 0%, #f0f7f0 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.1);
}

.cfca-checkbox {
    width: 20px;
    height: 20px;
    accent-color: var(--cfca-primary);
    cursor: pointer;
    transition: var(--cfca-transition);
}

/* Contador de resultados */
.cfca-counter {
    margin-left: auto;
    padding: 12px 24px;
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    border-radius: var(--cfca-border-radius-xl);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--cfca-primary-dark);
    border: 2px solid var(--cfca-primary-light);
    box-shadow: inset 0 2px 4px rgba(255,255,255,0.5);
}

/* =============================================================
   VISTA TABLA
   ============================================================= */
.cfca-table-container {
    background: white;
    border-radius: var(--cfca-border-radius-lg);
    overflow: hidden;
    border: 2px solid var(--cfca-gray-light);
    box-shadow: var(--cfca-box-shadow);
    margin-bottom: 30px;
}

.cfca-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 1000px;
}

.cfca-table thead {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    position: sticky;
    top: 0;
    z-index: 5;
}

.cfca-table th {
    padding: 18px 20px;
    text-align: left;
    font-weight: 600;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: white;
    position: relative;
}

.cfca-table th::after {
    content: '';
    position: absolute;
    right: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background: rgba(255, 255, 255, 0.2);
}

.cfca-table th:last-child::after {
    display: none;
}

.cfca-table td {
    padding: 16px 20px;
    border-bottom: 1px solid var(--cfca-gray-light);
    color: var(--cfca-dark);
    font-size: 0.95rem;
    transition: var(--cfca-transition);
}

.cfca-table tbody tr {
    cursor: pointer;
    transition: var(--cfca-transition);
    animation: fadeInRow 0.3s ease;
}

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

.cfca-table tbody tr:hover {
    background: linear-gradient(135deg, #f8fdfa 0%, #f0f7f0 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.1);
}

.cfca-table td:first-child {
    font-weight: 600;
    color: var(--cfca-primary);
}

/* Badges en tabla */
.cfca-badge-tipo {
    display: inline-block;
    padding: 6px 16px;
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    color: var(--cfca-primary-dark);
    border-radius: var(--cfca-border-radius-xl);
    font-weight: 600;
    font-size: 0.85rem;
    border: 1px solid var(--cfca-primary-light);
    box-shadow: inset 0 1px 3px rgba(255,255,255,0.5);
}

/* =============================================================
   VISTA TARJETAS
   ============================================================= */
.cfca-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 30px;
    margin-bottom: 30px;
}

.cfca-card {
    background: white;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-lg);
    padding: 25px;
    cursor: pointer;
    transition: var(--cfca-transition);
    box-shadow: 0 5px 20px rgba(0,0,0,0.03);
    position: relative;
    overflow: hidden;
    animation: fadeInCard 0.4s ease;
}

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

.cfca-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--cfca-primary), var(--cfca-primary-light));
    transform: scaleX(0);
    transition: transform 0.4s ease;
    transform-origin: left;
}

.cfca-card:hover::before {
    transform: scaleX(1);
}

.cfca-card:hover {
    transform: translateY(-8px);
    border-color: var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow-hover);
}

.cfca-card-title {
    font-weight: 700;
    font-size: 1.3rem;
    color: var(--cfca-primary);
    margin-bottom: 20px;
    line-height: 1.4;
}

.cfca-card-info {
    color: var(--cfca-gray);
    display: flex;
    flex-direction: column;
    gap: 12px;
    font-size: 0.95rem;
}

.cfca-card-info div {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--cfca-gray-light);
}

.cfca-card-info div:last-child {
    border-bottom: none;
}

.cfca-card-info i {
    width: 24px;
    color: var(--cfca-primary);
    font-size: 1.1rem;
}

/* =============================================================
   VISTA CALENDARIO
   ============================================================= */
.cfca-calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    background: linear-gradient(135deg, #ffffff 0%, #f8fdfa 100%);
    padding: 20px 30px;
    border-radius: var(--cfca-border-radius-lg);
    border: 2px solid var(--cfca-gray-light);
    box-shadow: var(--cfca-box-shadow);
}

.cfca-calendar-title {
    margin: 0;
    color: var(--cfca-primary);
    font-size: 2rem;
    font-weight: 700;
    text-shadow: 2px 2px 4px rgba(46, 125, 50, 0.1);
}

.cfca-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
    margin-bottom: 15px;
    text-align: center;
    font-weight: 700;
    color: white;
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    padding: 15px;
    border-radius: var(--cfca-border-radius-lg);
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cfca-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
    margin-bottom: 30px;
}

.cfca-calendar-day {
    min-height: 120px;
    padding: 12px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-sm);
    cursor: pointer;
    transition: var(--cfca-transition);
    background: white;
    animation: fadeInDay 0.3s ease;
    position: relative;
    display: flex;
    flex-direction: column;
}

@keyframes fadeInDay {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.cfca-calendar-day:hover {
    transform: translateY(-4px);
    border-color: var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow-hover);
    z-index: 2;
}

.cfca-calendar-day.other-month {
    background: linear-gradient(135deg, #f5f5f5 0%, #eeeeee 100%);
    opacity: 0.6;
}

.cfca-calendar-day.today {
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    border: 3px solid var(--cfca-primary);
    font-weight: bold;
    transform: scale(1.02);
    box-shadow: 0 0 0 4px rgba(46, 125, 50, 0.1);
}

.cfca-calendar-day-number {
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 8px;
    color: var(--cfca-primary);
}

.cfca-calendar-event {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    font-size: 0.7rem;
    padding: 4px 6px;
    border-radius: 4px;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 600;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    transition: var(--cfca-transition);
}

.cfca-calendar-event:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 8px rgba(46, 125, 50, 0.3);
}

/* =============================================================
   VISTA AGENDA
   ============================================================= */
#agenda-lista {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 30px;
}

#agenda-lista .cfca-card {
    animation: slideInAgenda 0.3s ease;
    padding: 20px 25px;
}

@keyframes slideInAgenda {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

#agenda-lista .cfca-card:hover {
    transform: translateX(8px) translateY(-2px);
}

/* =============================================================
   PAGINACIÓN
   ============================================================= */
.cfca-pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 30px;
    background: linear-gradient(135deg, #fafdfa 0%, #f5faf5 100%);
    border-radius: var(--cfca-border-radius-lg);
    flex-wrap: wrap;
    margin-top: 20px;
}

.cfca-page-btn {
    min-width: 45px;
    height: 45px;
    padding: 0 12px;
    border: 2px solid var(--cfca-gray-light);
    background: white;
    border-radius: var(--cfca-border-radius-sm);
    cursor: pointer;
    transition: var(--cfca-transition);
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--cfca-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.cfca-page-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    border-color: var(--cfca-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.2);
}

.cfca-page-btn.active {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    border-color: var(--cfca-primary);
    font-weight: 700;
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(46, 125, 50, 0.3);
}

.cfca-page-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background: var(--cfca-light);
}

/* =============================================================
   MODAL DE DETALLE
   ============================================================= */
.cfca-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.8);
    z-index: 10000;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(8px);
    animation: fadeInModal 0.3s ease;
}

@keyframes fadeInModal {
    from { opacity: 0; }
    to { opacity: 1; }
}

.cfca-modal.active {
    display: flex;
}

.cfca-modal-content {
    background: linear-gradient(135deg, #ffffff 0%, #f8fdfa 100%);
    border-radius: var(--cfca-border-radius-lg);
    max-width: 900px;
    width: 95%;
    max-height: 90vh;
    overflow-y: auto;
    padding: 40px;
    position: relative;
    box-shadow: 0 30px 80px rgba(0,0,0,0.4);
    animation: modalSlideIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border: 2px solid var(--cfca-primary);
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(-50px) scale(0.9);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.cfca-modal-close {
    position: absolute;
    top: 25px;
    right: 25px;
    background: linear-gradient(135deg, #f44336 0%, #d32f2f 100%);
    color: white;
    border: none;
    font-size: 28px;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 15px rgba(244,67,54,0.4);
    z-index: 10001;
    transition: var(--cfca-transition);
    border: 2px solid white;
}

.cfca-modal-close:hover {
    transform: scale(1.1) rotate(90deg);
    background: linear-gradient(135deg, #d32f2f 0%, #b71c1c 100%);
    box-shadow: 0 8px 20px rgba(244,67,54,0.5);
}

.cfca-modal-header {
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 3px solid var(--cfca-primary-light);
}

.cfca-modal-header h2 {
    color: var(--cfca-primary);
    font-size: 2rem;
    margin: 0;
    line-height: 1.3;
}

.cfca-modal-grid-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
    margin-bottom: 20px;
}

.cfca-info-card {
    background: white;
    padding: 25px;
    border-radius: var(--cfca-border-radius);
    border: 2px solid var(--cfca-gray-light);
    box-shadow: 0 5px 15px rgba(0,0,0,0.05);
    transition: var(--cfca-transition);
}

.cfca-info-card:hover {
    transform: translateY(-2px);
    border-color: var(--cfca-primary);
    box-shadow: 0 8px 25px rgba(46, 125, 50, 0.1);
}

.cfca-info-card h3 {
    color: var(--cfca-primary);
    margin: 0 0 20px 0;
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--cfca-gray-light);
}

.cfca-info-item {
    display: flex;
    margin-bottom: 12px;
    padding: 8px 0;
    border-bottom: 1px dashed var(--cfca-gray-light);
}

.cfca-info-item:last-child {
    border-bottom: none;
}

.cfca-info-item .label {
    width: 100px;
    font-weight: 600;
    color: var(--cfca-gray);
}

.cfca-info-item .value {
    flex: 1;
    color: var(--cfca-dark);
    font-weight: 500;
}

/* Validaciones */
.cfca-validaciones-section {
    background: linear-gradient(135deg, #f1f8e9 0%, #dcedc8 100%);
    padding: 20px 25px;
    border-radius: var(--cfca-border-radius);
    margin: 20px 0;
    border-left: 6px solid var(--cfca-primary);
}

.cfca-validaciones-titulo {
    font-weight: 700;
    color: var(--cfca-primary-dark);
    margin-bottom: 15px;
    font-size: 1.1rem;
}

.cfca-validaciones-tags {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.cfca-tag-validacion {
    padding: 8px 20px;
    border-radius: var(--cfca-border-radius-xl);
    font-weight: 600;
    font-size: 0.9rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.cfca-tag-fide {
    background: linear-gradient(135deg, #6a1b9a 0%, #4a148c 100%);
    color: white;
}

.cfca-tag-fecodaz {
    background: linear-gradient(135deg, #c6a43f 0%, #b38f2e 100%);
    color: white;
}

/* Suscripción */
.cfca-suscripcion-section {
    margin-top: 30px;
    text-align: center;
}

.cfca-btn-suscripcion {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 40px;
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    border: none;
    border-radius: var(--cfca-border-radius-xl);
    font-weight: 700;
    font-size: 1.1rem;
    cursor: pointer;
    transition: var(--cfca-transition);
    box-shadow: 0 6px 20px rgba(46, 125, 50, 0.3);
    text-decoration: none;
    border: 2px solid transparent;
}

.cfca-btn-suscripcion:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(46, 125, 50, 0.4);
    border-color: white;
}

/* =============================================================
   ENLACES Y BOTONES DE ACCIÓN
   ============================================================= */
.cfca-enlace-boton {
    display: inline-block;
    padding: 6px 15px;
    margin: 2px 4px;
    border-radius: var(--cfca-border-radius-xl);
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: 600;
    transition: var(--cfca-transition);
    border: none;
    cursor: pointer;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

.cfca-enlace-boton:hover {
    transform: translateY(-3px);
    filter: brightness(1.1);
    box-shadow: 0 5px 12px rgba(0,0,0,0.2);
}

.cfca-enlace-chess { 
    background: linear-gradient(135deg, #6a1b9a 0%, #4a148c 100%); 
    color: white; 
}

.cfca-enlace-lichess { 
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%); 
    color: white; 
}

.cfca-enlace-web { 
    background: linear-gradient(135deg, #1565c0 0%, #0d47a1 100%); 
    color: white; 
}

.cfca-enlace-flyer { 
    background: linear-gradient(135deg, #e65100 0%, #bf360c 100%); 
    color: white; 
}

.cfca-enlace-resolucion { 
    background: linear-gradient(135deg, #d32f2f 0%, #b71c1c 100%); 
    color: white; 
}

.cfca-sin-enlaces { 
    color: var(--cfca-gray); 
    font-size: 0.8rem; 
    font-style: italic; 
    padding: 4px 8px;
    background: var(--cfca-light);
    border-radius: var(--cfca-border-radius-sm);
}

/* =============================================================
   RESOLUCIONES
   ============================================================= */
.cfca-resoluciones-section {
    margin-top: 20px;
    padding: 20px;
    background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
    border-radius: var(--cfca-border-radius);
    border-left: 6px solid #d32f2f;
    box-shadow: 0 5px 15px rgba(211,47,47,0.1);
}

.cfca-resolucion-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    background: white;
    border-radius: var(--cfca-border-radius);
    margin-top: 10px;
    border: 1px solid #ffb74d;
}

.cfca-resolucion-link {
    color: #d32f2f;
    text-decoration: none;
    font-weight: 600;
    transition: var(--cfca-transition);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.cfca-resolucion-link:hover {
    color: #b71c1c;
    transform: translateX(5px);
}

/* =============================================================
   TOAST NOTIFICATIONS
   ============================================================= */
.cfca-toast {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    padding: 18px 35px;
    border-radius: var(--cfca-border-radius-xl);
    box-shadow: 0 10px 30px rgba(46, 125, 50, 0.4);
    display: none;
    z-index: 10002;
    font-weight: 600;
    animation: slideInToast 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border: 2px solid white;
    font-size: 1rem;
    align-items: center;
    gap: 10px;
}

@keyframes slideInToast {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.cfca-toast.error {
    background: linear-gradient(135deg, #f44336 0%, #c62828 100%);
    box-shadow: 0 10px 30px rgba(244,67,54,0.4);
}

.cfca-toast::before {
    content: '✅';
    font-size: 1.2rem;
}

.cfca-toast.error::before {
    content: '❌';
}

/* =============================================================
   ESTADÍSTICAS Y DASHBOARD
   ============================================================= */
.cfca-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin: 20px 0;
}

.cfca-stat-card {
    background: white;
    padding: 25px;
    border-radius: var(--cfca-border-radius);
    border-left: 6px solid var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow);
    transition: var(--cfca-transition);
}

.cfca-stat-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--cfca-box-shadow-hover);
}

.cfca-stat-icon {
    font-size: 2.5rem;
    margin-bottom: 15px;
}

.cfca-stat-number {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--cfca-primary);
    line-height: 1.2;
}

.cfca-stat-label {
    color: var(--cfca-gray);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* =============================================================
   LOADING ANIMATIONS
   ============================================================= */
.cfca-loading {
    text-align: center;
    padding: 60px;
    background: white;
    border-radius: var(--cfca-border-radius);
    box-shadow: var(--cfca-box-shadow);
    margin: 20px 0;
}

.cfca-spinner {
    display: inline-block;
    width: 50px;
    height: 50px;
    border: 5px solid var(--cfca-gray-light);
    border-top: 5px solid var(--cfca-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 20px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.cfca-pulse {
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* =============================================================
   RESPONSIVE DESIGN
   ============================================================= */
@media (max-width: 1200px) {
    .cfca-container {
        max-width: 95%;
        margin: 20px auto;
    }
}

@media (max-width: 992px) {
    .cfca-view-selector {
        flex-direction: column;
        padding: 15px;
    }
    
    .cfca-view-selector .cfca-btn-secondary {
        margin-left: 0;
    }
    
    .cfca-grid {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    }
    
    .cfca-calendar-header {
        flex-direction: column;
        gap: 15px;
        text-align: center;
    }
}

@media (max-width: 768px) {
    .cfca-filter-group {
        flex-direction: column;
    }
    
    .cfca-filters {
        padding: 20px;
    }
    
    .cfca-checkbox-group {
        flex-direction: column;
        align-items: stretch;
    }
    
    .cfca-checkbox-label {
        width: 100%;
        justify-content: center;
    }
    
    .cfca-counter {
        margin-left: 0;
        text-align: center;
    }
    
    .cfca-table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .cfca-table th,
    .cfca-table td {
        white-space: nowrap;
        padding: 12px 15px;
    }
    
    .cfca-calendar-header {
        padding: 15px;
    }
    
    .cfca-calendar-title {
        font-size: 1.5rem;
    }
    
    .cfca-weekdays {
        font-size: 0.9rem;
        padding: 10px;
    }
    
    .cfca-calendar-day {
        min-height: 80px;
        padding: 6px;
    }
    
    .cfca-calendar-day-number {
        font-size: 0.9rem;
    }
    
    .cfca-calendar-event {
        font-size: 0.6rem;
        padding: 2px 4px;
    }
    
    .cfca-modal-content {
        padding: 20px;
    }
    
    .cfca-modal-header h2 {
        font-size: 1.5rem;
    }
    
    .cfca-modal-grid-2 {
        grid-template-columns: 1fr;
    }
    
    .cfca-toast {
        bottom: 20px;
        right: 20px;
        left: 20px;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .cfca-grid {
        grid-template-columns: 1fr;
    }
    
    .cfca-card {
        padding: 20px;
    }
    
    .cfca-card-title {
        font-size: 1.1rem;
    }
    
    .cfca-pagination button {
        min-width: 35px;
        height: 35px;
        font-size: 0.85rem;
    }
    
    .cfca-calendar-grid {
        gap: 3px;
    }
    
    .cfca-calendar-day {
        min-height: 60px;
        padding: 3px;
    }
    
    .cfca-calendar-day-number {
        font-size: 0.8rem;
    }
}


/* =============================================================
   UTILIDADES (CONTINUACIÓN)
   ============================================================= */
.cfca-mb-3 { margin-bottom: 30px; }
.cfca-ml-1 { margin-left: 10px; }
.cfca-ml-2 { margin-left: 20px; }
.cfca-mr-1 { margin-right: 10px; }
.cfca-mr-2 { margin-right: 20px; }
.cfca-p-1 { padding: 10px; }
.cfca-p-2 { padding: 20px; }
.cfca-p-3 { padding: 30px; }

.cfca-text-center { text-align: center; }
.cfca-text-left { text-align: left; }
.cfca-text-right { text-align: right; }
.cfca-text-justify { text-align: justify; }

.cfca-font-bold { font-weight: 700; }
.cfca-font-semibold { font-weight: 600; }
.cfca-font-medium { font-weight: 500; }
.cfca-font-normal { font-weight: 400; }
.cfca-font-light { font-weight: 300; }

.cfca-flex { display: flex; }
.cfca-flex-col { flex-direction: column; }
.cfca-flex-wrap { flex-wrap: wrap; }
.cfca-items-center { align-items: center; }
.cfca-items-start { align-items: flex-start; }
.cfca-items-end { align-items: flex-end; }
.cfca-justify-center { justify-content: center; }
.cfca-justify-between { justify-content: space-between; }
.cfca-justify-around { justify-content: space-around; }
.cfca-justify-end { justify-content: flex-end; }
.cfca-gap-1 { gap: 10px; }
.cfca-gap-2 { gap: 20px; }
.cfca-gap-3 { gap: 30px; }

.cfca-w-full { width: 100%; }
.cfca-w-auto { width: auto; }
.cfca-h-full { height: 100%; }
.cfca-h-auto { height: auto; }

.cfca-rounded { border-radius: var(--cfca-border-radius); }
.cfca-rounded-sm { border-radius: var(--cfca-border-radius-sm); }
.cfca-rounded-lg { border-radius: var(--cfca-border-radius-lg); }
.cfca-rounded-xl { border-radius: var(--cfca-border-radius-xl); }
.cfca-rounded-full { border-radius: 9999px; }

.cfca-shadow { box-shadow: var(--cfca-box-shadow); }
.cfca-shadow-hover { box-shadow: var(--cfca-box-shadow-hover); }
.cfca-shadow-none { box-shadow: none; }

.cfca-border { border: 2px solid var(--cfca-border); }
.cfca-border-primary { border-color: var(--cfca-primary); }
.cfca-border-light { border-color: var(--cfca-gray-light); }

/* =============================================================
   ANIMACIONES ADICIONALES
   ============================================================= */
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

@keyframes glow {
    0%, 100% { box-shadow: 0 0 10px rgba(46, 125, 50, 0.3); }
    50% { box-shadow: 0 0 20px rgba(46, 125, 50, 0.6); }
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slideInLeft {
    from {
        transform: translateX(-100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes bounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.cfca-animate-float { animation: float 3s ease-in-out infinite; }
.cfca-animate-glow { animation: glow 2s ease-in-out infinite; }
.cfca-animate-bounce { animation: bounce 1s ease-in-out; }
.cfca-animate-slide-right { animation: slideInRight 0.5s ease; }
.cfca-animate-slide-left { animation: slideInLeft 0.5s ease; }

/* =============================================================
   TEMA OSCURO (OPCIONAL)
   ============================================================= */
@media (prefers-color-scheme: dark) {
    .cfca-dark-mode-support {
        --cfca-light: #2d2d2d;
        --cfca-dark: #ffffff;
        --cfca-gray: #b0b0b0;
        --cfca-gray-light: #404040;
        --cfca-border: #404040;
    }
}

/* =============================================================
   IMPRESIÓN
   ============================================================= */
@media print {
    .cfca-view-selector,
    .cfca-filters,
    .cfca-pagination,
    .cfca-btn-primary,
    .cfca-btn-secondary,
    .cfca-modal-close,
    .cfca-toast,
    .cfca-suscripcion-section {
        display: none !important;
    }
    
    .cfca-table {
        border: 2px solid black;
    }
    
    .cfca-table th {
        background: #f0f0f0 !important;
        color: black !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
    
    .cfca-card {
        break-inside: avoid;
        page-break-inside: avoid;
        border: 1px solid #ccc;
        box-shadow: none;
    }
    
    .cfca-modal {
        position: absolute;
        background: white;
    }
    
    .cfca-modal-content {
        box-shadow: none;
        border: 2px solid black;
    }
}

/* =============================================================
   ACCESIBILIDAD
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

.cfca-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--cfca-primary);
    color: white;
    padding: 10px 20px;
    text-decoration: none;
    z-index: 100000;
}

.cfca-skip-link:focus {
    left: 0;
}

.cfca-focus-visible:focus-visible {
    outline: 3px solid var(--cfca-primary);
    outline-offset: 2px;
}

/* =============================================================
   SCROLL PERSONALIZADO
   ============================================================= */
.cfca-custom-scroll::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

.cfca-custom-scroll::-webkit-scrollbar-track {
    background: var(--cfca-gray-light);
    border-radius: 5px;
}

.cfca-custom-scroll::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, var(--cfca-primary), var(--cfca-primary-dark));
    border-radius: 5px;
    border: 2px solid var(--cfca-gray-light);
}

.cfca-custom-scroll::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, var(--cfca-primary-dark), var(--cfca-primary));
}

/* =============================================================
   TEMA PERSONALIZADO POR USUARIO
   ============================================================= */
.cfca-theme-custom {
    --cfca-primary: var(--user-primary, #2e7d32);
    --cfca-primary-light: var(--user-primary-light, #4caf50);
    --cfca-primary-dark: var(--user-primary-dark, #1b5e20);
}

.cfca-color-picker {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 3px solid white;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    cursor: pointer;
    transition: var(--cfca-transition);
}

.cfca-color-picker:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
}

/* =============================================================
   ESTADOS VACÍOS Y ERRORES
   ============================================================= */
.cfca-empty-state {
    text-align: center;
    padding: 80px 20px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-radius: var(--cfca-border-radius-lg);
    margin: 40px 0;
}

.cfca-empty-icon {
    font-size: 5rem;
    margin-bottom: 20px;
    opacity: 0.5;
}

.cfca-empty-title {
    font-size: 1.5rem;
    color: var(--cfca-gray);
    margin-bottom: 10px;
}

.cfca-empty-message {
    color: var(--cfca-gray);
    font-size: 1rem;
}

.cfca-error-state {
    background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
    border: 2px solid var(--cfca-danger);
    border-radius: var(--cfca-border-radius);
    padding: 30px;
    text-align: center;
    margin: 20px 0;
}

.cfca-error-icon {
    font-size: 3rem;
    margin-bottom: 15px;
}

.cfca-error-title {
    color: var(--cfca-danger);
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 10px;
}

.cfca-error-message {
    color: #b71c1c;
    margin-bottom: 20px;
}

/* =============================================================
   TOOLTIPS Y POPOVERS
   ============================================================= */
.cfca-tooltip {
    position: relative;
    display: inline-block;
}

.cfca-tooltip .cfca-tooltip-text {
    visibility: hidden;
    width: 200px;
    background: linear-gradient(135deg, var(--cfca-dark) 0%, #1a1a1a 100%);
    color: white;
    text-align: center;
    border-radius: var(--cfca-border-radius-sm);
    padding: 8px 12px;
    position: absolute;
    z-index: 1000;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    transition: opacity 0.3s;
    font-size: 0.85rem;
    pointer-events: none;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.1);
}

.cfca-tooltip .cfca-tooltip-text::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: var(--cfca-dark) transparent transparent transparent;
}

.cfca-tooltip:hover .cfca-tooltip-text {
    visibility: visible;
    opacity: 1;
}

/* =============================================================
   BADGES Y ETIQUETAS AVANZADAS
   ============================================================= */
.cfca-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--cfca-border-radius-xl);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cfca-badge-primary {
    background: linear-gradient(135deg, var(--cfca-primary), var(--cfca-primary-dark));
    color: white;
}

.cfca-badge-success {
    background: linear-gradient(135deg, var(--cfca-success), #1e7e34);
    color: white;
}

.cfca-badge-danger {
    background: linear-gradient(135deg, var(--cfca-danger), #b71c1c);
    color: white;
}

.cfca-badge-warning {
    background: linear-gradient(135deg, var(--cfca-warning), #ff8f00);
    color: var(--cfca-dark);
}

.cfca-badge-info {
    background: linear-gradient(135deg, var(--cfca-info), #0d47a1);
    color: white;
}

.cfca-badge-outline {
    background: transparent;
    border: 2px solid currentColor;
}

/* =============================================================
   PROGRESS BARS
   ============================================================= */
.cfca-progress {
    width: 100%;
    height: 8px;
    background: var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-xl);
    overflow: hidden;
    margin: 10px 0;
}

.cfca-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--cfca-primary), var(--cfca-primary-light));
    border-radius: var(--cfca-border-radius-xl);
    transition: width 0.3s ease;
    position: relative;
    overflow: hidden;
}

.cfca-progress-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* =============================================================
   TIMELINE
   ============================================================= */
.cfca-timeline {
    position: relative;
    padding: 20px 0;
}

.cfca-timeline::before {
    content: '';
    position: absolute;
    left: 50%;
    width: 2px;
    height: 100%;
    background: linear-gradient(to bottom, transparent, var(--cfca-primary), transparent);
    transform: translateX(-50%);
}

.cfca-timeline-item {
    position: relative;
    margin-bottom: 30px;
    width: 100%;
}

.cfca-timeline-item:nth-child(odd) {
    padding-right: calc(50% + 20px);
}

.cfca-timeline-item:nth-child(even) {
    padding-left: calc(50% + 20px);
}

.cfca-timeline-dot {
    position: absolute;
    left: 50%;
    width: 16px;
    height: 16px;
    background: var(--cfca-primary);
    border: 3px solid white;
    border-radius: 50%;
    transform: translateX(-50%);
    box-shadow: 0 0 0 3px rgba(46,125,50,0.2);
    z-index: 2;
}

.cfca-timeline-content {
    background: white;
    padding: 20px;
    border-radius: var(--cfca-border-radius);
    border: 2px solid var(--cfca-gray-light);
    box-shadow: var(--cfca-box-shadow);
    transition: var(--cfca-transition);
}

.cfca-timeline-content:hover {
    transform: translateY(-3px);
    border-color: var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow-hover);
}

/* =============================================================
   STATS CARDS AVANZADAS
   ============================================================= */
.cfca-stats-grid-advanced {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 25px;
    margin: 30px 0;
}

.cfca-stat-card-advanced {
    background: white;
    border-radius: var(--cfca-border-radius-lg);
    padding: 25px;
    box-shadow: var(--cfca-box-shadow);
    transition: var(--cfca-transition);
    position: relative;
    overflow: hidden;
}

.cfca-stat-card-advanced::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(46,125,50,0.1) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.5s;
}

.cfca-stat-card-advanced:hover::before {
    opacity: 1;
}

.cfca-stat-card-advanced:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 20px 40px rgba(46,125,50,0.15);
}

.cfca-stat-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}

.cfca-stat-icon-large {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--cfca-primary-light), var(--cfca-primary));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: white;
    box-shadow: 0 10px 20px rgba(46,125,50,0.2);
}

.cfca-stat-trend {
    padding: 4px 12px;
    border-radius: var(--cfca-border-radius-xl);
    font-size: 0.85rem;
    font-weight: 600;
}

.cfca-stat-trend.up {
    background: #d4edda;
    color: #155724;
}

.cfca-stat-trend.down {
    background: #f8d7da;
    color: #721c24;
}

.cfca-stat-value-large {
    font-size: 3rem;
    font-weight: 700;
    color: var(--cfca-primary);
    line-height: 1.2;
    margin-bottom: 10px;
}

.cfca-stat-label-large {
    font-size: 1rem;
    color: var(--cfca-gray);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.cfca-stat-footer {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 2px dashed var(--cfca-gray-light);
    display: flex;
    justify-content: space-between;
    color: var(--cfca-gray);
    font-size: 0.9rem;
}

/* =============================================================
   FILTROS AVANZADOS - MEJORAS
   ============================================================= */
.cfca-advanced-filters {
    background: linear-gradient(135deg, #ffffff 0%, #f0f7f0 100%);
    padding: 30px;
    border-radius: var(--cfca-border-radius-lg);
    margin-bottom: 30px;
    border: 2px solid var(--cfca-primary-light);
    box-shadow: var(--cfca-box-shadow);
}

.cfca-filter-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.cfca-filter-label {
    display: block;
    font-weight: 600;
    color: var(--cfca-primary);
    margin-bottom: 8px;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cfca-filter-input {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius);
    font-size: 0.95rem;
    transition: var(--cfca-transition);
    background: white;
}

.cfca-filter-input:focus {
    border-color: var(--cfca-primary);
    outline: none;
    box-shadow: 0 0 0 4px rgba(46,125,50,0.1);
}

.cfca-filter-select {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius);
    font-size: 0.95rem;
    background: white;
    cursor: pointer;
    transition: var(--cfca-transition);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232e7d32' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 15px center;
    padding-right: 45px;
}

.cfca-filter-select:hover {
    border-color: var(--cfca-primary);
    transform: translateY(-1px);
}

.cfca-active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
    padding: 15px;
    background: white;
    border-radius: var(--cfca-border-radius);
    border: 1px solid var(--cfca-gray-light);
}

.cfca-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 15px;
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    color: var(--cfca-primary-dark);
    border-radius: var(--cfca-border-radius-xl);
    font-size: 0.9rem;
    font-weight: 500;
    border: 1px solid var(--cfca-primary-light);
}

.cfca-filter-tag-remove {
    cursor: pointer;
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: white;
    color: var(--cfca-danger);
    font-size: 12px;
    font-weight: bold;
    transition: var(--cfca-transition);
}

.cfca-filter-tag-remove:hover {
    background: var(--cfca-danger);
    color: white;
    transform: scale(1.1);
}

/* =============================================================
   TABLA DE EVENTOS - MEJORAS
   ============================================================= */
.cfca-table-wrapper {
    border-radius: var(--cfca-border-radius-lg);
    background: white;
    box-shadow: var(--cfca-box-shadow);
    overflow: hidden;
    margin-bottom: 30px;
}

.cfca-table-header {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    padding: 15px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: white;
}

.cfca-table-title {
    font-weight: 600;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    gap: 10px;
}

.cfca-table-actions {
    display: flex;
    gap: 10px;
}

.cfca-table-action-btn {
    background: rgba(255,255,255,0.2);
    border: none;
    color: white;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--cfca-transition);
}

.cfca-table-action-btn:hover {
    background: white;
    color: var(--cfca-primary);
    transform: scale(1.1);
}

.cfca-table-container {
    overflow-x: auto;
    max-height: 600px;
    overflow-y: auto;
}

.cfca-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 1000px;
}

.cfca-table th {
    background: var(--cfca-primary);
    color: white;
    padding: 16px 20px;
    text-align: left;
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: sticky;
    top: 0;
    z-index: 10;
    white-space: nowrap;
}

.cfca-table th.sortable {
    cursor: pointer;
    user-select: none;
    padding-right: 30px;
    position: relative;
}

.cfca-table th.sortable::after {
    content: '↕️';
    position: absolute;
    right: 10px;
    opacity: 0.5;
    font-size: 0.8rem;
}

.cfca-table th.sortable.asc::after {
    content: '↑';
    opacity: 1;
}

.cfca-table th.sortable.desc::after {
    content: '↓';
    opacity: 1;
}

.cfca-table td {
    padding: 14px 20px;
    border-bottom: 1px solid var(--cfca-gray-light);
    color: var(--cfca-dark);
    font-size: 0.95rem;
    transition: var(--cfca-transition);
}

.cfca-table tbody tr {
    cursor: pointer;
    transition: var(--cfca-transition);
    animation: fadeInRow 0.3s ease;
}

.cfca-table tbody tr:hover {
    background: linear-gradient(135deg, #f8fdfa 0%, #f0f7f0 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(46,125,50,0.1);
}

.cfca-table tbody tr.selected {
    background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
    border-left: 4px solid var(--cfca-primary);
}

/* =============================================================
   EXPORTACIÓN Y COMPARTIR
   ============================================================= */
.cfca-share-menu {
    position: relative;
    display: inline-block;
}

.cfca-share-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    background: white;
    border-radius: var(--cfca-border-radius);
    box-shadow: var(--cfca-box-shadow-hover);
    min-width: 200px;
    z-index: 1000;
    display: none;
    border: 2px solid var(--cfca-gray-light);
    overflow: hidden;
    margin-top: 10px;
}

.cfca-share-menu:hover .cfca-share-dropdown {
    display: block;
    animation: slideInRight 0.3s ease;
}

.cfca-share-item {
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: var(--cfca-transition);
    border-bottom: 1px solid var(--cfca-gray-light);
}

.cfca-share-item:last-child {
    border-bottom: none;
}

.cfca-share-item:hover {
    background: var(--cfca-light);
    color: var(--cfca-primary);
    transform: translateX(5px);
}

.cfca-share-icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 0.9rem;
}

.cfca-share-icon.whatsapp { background: #25D366; }
.cfca-share-icon.facebook { background: #1877F2; }
.cfca-share-icon.twitter { background: #1DA1F2; }
.cfca-share-icon.email { background: #EA4335; }
.cfca-share-icon.copy { background: var(--cfca-primary); }

/* =============================================================
   CALENDARIO MEJORADO
   ============================================================= */
.cfca-calendar-controls {
    display: flex;
    gap: 10px;
    align-items: center;
}

.cfca-calendar-nav-btn {
    width: 40px;
    height: 40px;
    border: 2px solid var(--cfca-gray-light);
    background: white;
    border-radius: 50%;
    cursor: pointer;
    transition: var(--cfca-transition);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.cfca-calendar-nav-btn:hover:not(:disabled) {
    background: var(--cfca-primary);
    color: white;
    border-color: var(--cfca-primary);
    transform: scale(1.1);
}

.cfca-calendar-nav-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.cfca-calendar-today-btn {
    padding: 8px 20px;
    background: white;
    border: 2px solid var(--cfca-primary);
    color: var(--cfca-primary);
    border-radius: var(--cfca-border-radius-xl);
    font-weight: 600;
    cursor: pointer;
    transition: var(--cfca-transition);
}

.cfca-calendar-today-btn:hover {
    background: var(--cfca-primary);
    color: white;
}

.cfca-calendar-day.has-events {
    position: relative;
}

.cfca-calendar-day.has-events::after {
    content: '';
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 8px;
    height: 8px;
    background: var(--cfca-primary);
    border-radius: 50%;
    box-shadow: 0 0 0 2px white;
}

.cfca-calendar-day.has-events.multiple::after {
    background: var(--cfca-accent);
}

.cfca-calendar-event-badge {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--cfca-primary);
    color: white;
    font-size: 0.7rem;
    line-height: 20px;
    text-align: center;
    margin-left: 2px;
}

/* =============================================================
   AGENDA MEJORADA
   ============================================================= */
.cfca-agenda-timeline {
    position: relative;
    padding-left: 100px;
}

.cfca-agenda-item {
    position: relative;
    margin-bottom: 20px;
    padding: 20px;
    background: white;
    border-radius: var(--cfca-border-radius);
    border: 2px solid var(--cfca-gray-light);
    transition: var(--cfca-transition);
    cursor: pointer;
}

.cfca-agenda-item:hover {
    transform: translateX(5px);
    border-color: var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow);
}

.cfca-agenda-time {
    position: absolute;
    left: -80px;
    top: 20px;
    width: 70px;
    text-align: right;
    font-weight: 600;
    color: var(--cfca-primary);
    font-size: 0.9rem;
}

.cfca-agenda-time::after {
    content: '';
    position: absolute;
    right: -15px;
    top: 50%;
    width: 10px;
    height: 10px;
    background: var(--cfca-primary);
    border-radius: 50%;
    transform: translateY(-50%);
    box-shadow: 0 0 0 3px rgba(46,125,50,0.2);
}

.cfca-agenda-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}

.cfca-agenda-title {
    font-weight: 600;
    color: var(--cfca-dark);
    font-size: 1.1rem;
}

.cfca-agenda-location {
    color: var(--cfca-gray);
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 5px;
}

.cfca-agenda-badge {
    padding: 4px 12px;
    border-radius: var(--cfca-border-radius-xl);
    font-size: 0.8rem;
    font-weight: 600;
    background: var(--cfca-light);
    color: var(--cfca-primary);
}

/* =============================================================
   NOTIFICACIONES MEJORADAS
   ============================================================= */
.cfca-notification-center {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 10001;
    width: 350px;
}

.cfca-notification {
    background: white;
    border-radius: var(--cfca-border-radius);
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    margin-bottom: 10px;
    padding: 20px;
    border-left: 6px solid var(--cfca-primary);
    animation: slideInRight 0.3s ease;
    position: relative;
    overflow: hidden;
}

.cfca-notification::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: linear-gradient(90deg, var(--cfca-primary), transparent);
    animation: progress 5s linear;
}

@keyframes progress {
    0% { width: 100%; }
    100% { width: 0%; }
}

.cfca-notification.success { border-left-color: var(--cfca-success); }
.cfca-notification.error { border-left-color: var(--cfca-danger); }
.cfca-notification.warning { border-left-color: var(--cfca-warning); }

.cfca-notification-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.cfca-notification-title {
    font-weight: 600;
    color: var(--cfca-dark);
}

.cfca-notification-close {
    cursor: pointer;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--cfca-transition);
}

.cfca-notification-close:hover {
    background: var(--cfca-light);
    transform: rotate(90deg);
}

.cfca-notification-message {
    color: var(--cfca-gray);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* =============================================================
   EDITOR DE EVENTOS MEJORADO
   ============================================================= */
.cfca-editor {
    max-width: 1200px;
    margin: 30px auto;
    background: white;
    border-radius: var(--cfca-border-radius-lg);
    box-shadow: var(--cfca-box-shadow);
    overflow: hidden;
}

.cfca-editor-header {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    padding: 25px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.cfca-editor-title {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.cfca-editor-actions {
    display: flex;
    gap: 10px;
}

.cfca-editor-tabs {
    display: flex;
    gap: 5px;
    background: var(--cfca-light);
    padding: 15px 20px;
    border-bottom: 3px solid var(--cfca-primary);
    flex-wrap: wrap;
    position: relative;
}

.cfca-editor-tab {
    padding: 12px 25px;
    background: white;
    color: var(--cfca-primary);
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius-xl);
    cursor: pointer;
    font-weight: 600;
    transition: var(--cfca-transition);
    position: relative;
    overflow: hidden;
}

.cfca-editor-tab:hover {
    transform: translateY(-2px);
    border-color: var(--cfca-primary);
    box-shadow: 0 4px 12px rgba(46,125,50,0.1);
}

.cfca-editor-tab.active {
    background: var(--cfca-primary);
    color: white;
    border-color: var(--cfca-primary);
    box-shadow: 0 4px 12px rgba(46,125,50,0.3);
}

.cfca-form-panel {
    background: white;
    padding: 30px;
    border: 2px solid var(--cfca-gray-light);
    border-top: none;
}

.cfca-field-group {
    background: var(--cfca-light);
    padding: 25px;
    border-radius: var(--cfca-border-radius);
    margin-bottom: 25px;
    border-left: 6px solid var(--cfca-primary);
    transition: var(--cfca-transition);
}

.cfca-field-group:hover {
    transform: translateX(5px);
    box-shadow: 0 5px 15px rgba(46,125,50,0.1);
}

.cfca-field-group h3 {
    margin: 0 0 20px 0;
    color: var(--cfca-primary);
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 2px dashed var(--cfca-gray-light);
}

.cfca-field-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-bottom: 20px;
}

.cfca-field {
    margin-bottom: 15px;
}

.cfca-field label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--cfca-primary);
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cfca-field input,
.cfca-field select,
.cfca-field textarea {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius);
    font-size: 0.95rem;
    transition: var(--cfca-transition);
    background: white;
    font-family: inherit;
}

.cfca-field input:focus,
.cfca-field select:focus,
.cfca-field textarea:focus {
    border-color: var(--cfca-primary);
    outline: none;
    box-shadow: 0 0 0 4px rgba(46,125,50,0.1);
    transform: translateY(-1px);
}

.cfca-field input:hover,
.cfca-field select:hover,
.cfca-field textarea:hover {
    border-color: var(--cfca-primary-light);
}

.cfca-checkbox-field {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
    padding: 10px;
    background: white;
    border-radius: var(--cfca-border-radius);
    border: 1px solid var(--cfca-gray-light);
    transition: var(--cfca-transition);
}

.cfca-checkbox-field:hover {
    border-color: var(--cfca-primary);
    background: var(--cfca-light);
}

.cfca-checkbox-field input[type="checkbox"] {
    width: 20px;
    height: 20px;
    accent-color: var(--cfca-primary);
    cursor: pointer;
}

.cfca-liga-selector {
    background: linear-gradient(135deg, #f8fdfa 0%, #e8f5e9 100%);
    padding: 25px;
    border-radius: var(--cfca-border-radius);
    margin-bottom: 25px;
    border: 2px solid var(--cfca-primary);
    position: relative;
    overflow: hidden;
}

.cfca-liga-selector::before {
    content: '🏷️';
    position: absolute;
    top: -20px;
    right: -20px;
    font-size: 100px;
    opacity: 0.1;
    transform: rotate(15deg);
}

.cfca-liga-selector h3 {
    margin: 0 0 15px 0;
    color: var(--cfca-primary);
    font-size: 1.3rem;
    position: relative;
    z-index: 1;
}

.cfca-notification-preview {
    background: linear-gradient(135deg, #fff3e0 0%, #ffe0b2 100%);
    padding: 20px;
    border-radius: var(--cfca-border-radius);
    margin-top: 15px;
    border-left: 6px solid #ff9800;
    position: relative;
}

.cfca-notification-preview::before {
    content: '📋 PREVIEW';
    position: absolute;
    top: -10px;
    left: 20px;
    background: #ff9800;
    color: white;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
}

.cfca-btn-add {
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    color: white;
    border: none;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--cfca-transition);
    box-shadow: 0 4px 12px rgba(46,125,50,0.3);
    font-size: 20px;
    font-weight: bold;
}

.cfca-btn-add:hover {
    transform: scale(1.1) rotate(90deg);
    box-shadow: 0 6px 16px rgba(46,125,50,0.4);
}

/* =============================================================
   DASHBOARD MEJORADO
   ============================================================= */
.cfca-dashboard {
    max-width: 1400px;
    margin: 30px auto;
}

.cfca-dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    padding: 20px;
    background: linear-gradient(135deg, var(--cfca-primary) 0%, var(--cfca-primary-dark) 100%);
    border-radius: var(--cfca-border-radius-lg);
    color: white;
}

.cfca-dashboard-title {
    font-size: 2rem;
    font-weight: 700;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 15px;
}

.cfca-dashboard-actions {
    display: flex;
    gap: 15px;
}

.cfca-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 25px;
    margin-bottom: 30px;
}

.cfca-dashboard-card {
    background: white;
    border-radius: var(--cfca-border-radius-lg);
    padding: 25px;
    box-shadow: var(--cfca-box-shadow);
    transition: var(--cfca-transition);
    border: 2px solid var(--cfca-gray-light);
    position: relative;
    overflow: hidden;
}

.cfca-dashboard-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, rgba(46,125,50,0.1) 0%, transparent 70%);
    border-radius: 50%;
}

.cfca-dashboard-card:hover {
    transform: translateY(-5px);
    border-color: var(--cfca-primary);
    box-shadow: var(--cfca-box-shadow-hover);
}

.cfca-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid var(--cfca-gray-light);
}

.cfca-card-header h3 {
    margin: 0;
    color: var(--cfca-primary);
    font-size: 1.2rem;
}

.cfca-card-icon {
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, var(--cfca-primary-light), var(--cfca-primary));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.5rem;
}

.cfca-card-content {
    color: var(--cfca-gray);
    line-height: 1.6;
}

.cfca-card-footer {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 2px dashed var(--cfca-gray-light);
    text-align: right;
}

.cfca-card-link {
    color: var(--cfca-primary);
    text-decoration: none;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    transition: var(--cfca-transition);
}

.cfca-card-link:hover {
    gap: 10px;
    color: var(--cfca-primary-dark);
}

/* =============================================================
   LOADING STATES AVANZADOS
   ============================================================= */
.cfca-skeleton {
    background: linear-gradient(90deg, 
        var(--cfca-gray-light) 25%, 
        #f0f0f0 50%, 
        var(--cfca-gray-light) 75%);
    background-size: 200% 100%;
    animation: loading 1.5s infinite;
    border-radius: var(--cfca-border-radius);
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.cfca-skeleton-text {
    height: 1em;
    margin-bottom: 0.5em;
}

.cfca-skeleton-title {
    height: 1.5em;
    width: 60%;
    margin-bottom: 1em;
}

.cfca-skeleton-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
}

.cfca-skeleton-thumbnail {
    width: 100%;
    height: 200px;
    border-radius: var(--cfca-border-radius);
}

/* =============================================================
   FIN DEL CSS - VERSIÓN 4.6.2
   ============================================================= */

/* === v4: Modal detail layout: better space usage === */
.cfca-modal-body{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.cfca-inner-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:14px;
}

.cfca-info-item{
    display:flex;
    flex-direction:column;
    gap:6px;
    margin:0;
    padding:14px 16px;
    border:1px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius);
    background: linear-gradient(135deg, #f9fffb 0%, #f2fbf4 100%);
}

.cfca-info-item .label{
    width:auto;
    font-weight:700;
    font-size:0.78rem;
    letter-spacing:0.04em;
    text-transform:uppercase;
    color: var(--cfca-gray);
}

.cfca-info-item .value{
    font-weight:700;
    font-size:1.08rem;
    color: var(--cfca-dark);
    word-break:break-word;
}

/* Bring important links to the top visually */
.cfca-links-section{
    order:-1;
    border:1px solid var(--cfca-gray-light);
    border-radius: var(--cfca-border-radius);
    padding:14px 16px;
    background:#fff;
}

.cfca-links-section h4{
    margin:0 0 10px 0;
    color: var(--cfca-primary);
    font-size:1rem;
}

.cfca-links-container{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

/* Map JS classes to existing button styles */
.cfca-link-button{ 
    display:inline-block;
    padding: 6px 15px;
    margin: 0;
    border-radius: var(--cfca-border-radius-xl);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 700;
    transition: var(--cfca-transition);
    border: none;
    cursor: pointer;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}
.cfca-link-button:hover{
    transform: translateY(-3px);
    filter: brightness(1.1);
    box-shadow: 0 5px 12px rgba(0,0,0,0.2);
}
.cfca-link-resolucion{ background: linear-gradient(135deg, #d32f2f 0%, #b71c1c 100%); color:white; }


/* === v5: Hide 'Válido FECODAZ / FIDE' UI === */
.cfca-validos, .cfca-filtro-validos, .cfca-badge-validos,
.cfca-valido-fide, .cfca-valido-fecodaz { display: none !important; }

.cfca-field #edit-valido-fide, .cfca-field #edit-valido-fecodaz { display:none !important; }

/* --- FIX: permitir paginación visible y evitar recortes --- */
.cfca-table-container {
  overflow: visible !important;
}

.cfca-table-container > div[style*="overflow-x"] {
  overflow-x: auto !important;
  overflow-y: visible !important;
}

.cfca-pagination {
  margin-bottom: 24px !important;
}
/* =============================================================
   OVERRIDE PREMIUM EDITOR FCA
   Pegar al final del archivo
   ============================================================= */

.cfca-editor{
  max-width: 1280px;
  margin: 28px auto;
  background: linear-gradient(180deg,#f8fff9 0%,#f4fbf6 100%);
  border: 1px solid #d9efe0;
  border-radius: 24px;
  box-shadow: 0 16px 38px rgba(2,6,23,.08);
  overflow: hidden;
}

.cfca-editor-header{
  background: linear-gradient(135deg, var(--cfca-primary-dark) 0%, var(--cfca-primary) 55%, var(--cfca-primary-light) 100%);
  padding: 20px 22px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.12);
}

.cfca-editor-title{
  margin: 0;
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .2px;
}

.cfca-editor-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}

.cfca-btn-primary{
  min-height: 48px;
  padding: 12px 22px;
  border: none;
  border-radius: 16px;
  background: linear-gradient(135deg,#166534 0%, #22c55e 100%);
  color: #fff;
  font-size: .98rem;
  font-weight: 800;
  letter-spacing: .2px;
  box-shadow: 0 12px 22px rgba(21,128,61,.22);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.cfca-btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 26px rgba(21,128,61,.28);
  filter: brightness(1.02);
}

/* Tabs más centradas y elegantes */
.cfca-editor-tabs{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 16px 18px;
  background: linear-gradient(180deg,#fcfffc 0%,#f5fbf6 100%);
  border-bottom: 1px solid #dfeee4;
}

.cfca-editor-tab{
  min-height: 42px;
  padding: 10px 16px;
  border: 1px solid #dfeee4;
  border-radius: 999px;
  background: #fff;
  color: var(--cfca-primary-dark);
  font-size: .93rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  box-shadow: 0 2px 8px rgba(21,128,61,.05);
  transition:
    background .22s ease,
    color .22s ease,
    border-color .22s ease,
    transform .18s ease,
    box-shadow .22s ease;
}

.cfca-editor-tab:hover{
  background: #f0fbf3;
  border-color: #bfe3c9;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(21,128,61,.10);
}

.cfca-editor-tab.active{
  background: linear-gradient(135deg,var(--cfca-primary-dark) 0%, var(--cfca-primary-light) 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 20px rgba(46,125,50,.24);
}

/* Panel principal */
.cfca-form-panel{
  padding: 20px;
  background: transparent;
  border: 0;
}

/* Contenido de tabs */
.tab-content{
  display: none;
  background: #fff;
  border: 1px solid #e4f1e8;
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 10px 22px rgba(21,128,61,.06);
}

.tab-content.active{
  display: block;
  animation: cfcaFadeTab .22s ease;
}

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

/* Grid más limpio */
.cfca-form-grid,
.cfca-field-row{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

/* Tarjetas de campo */
.cfca-field,
.cfca-field-group{
  background: linear-gradient(180deg,#fcfffc 0%,#f7fcf8 100%);
  border: 1px solid #e2f0e6;
  border-radius: 18px;
  padding: 14px;
  margin-bottom: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.cfca-field:hover,
.cfca-field-group:hover{
  transform: translateY(-1px);
  border-color: #c5e4cf;
  box-shadow: 0 8px 18px rgba(21,128,61,.08);
}

.cfca-field label{
  display: block;
  margin-bottom: 8px;
  color: #1f2937;
  font-size: .9rem;
  font-weight: 800;
  text-transform: none;
  letter-spacing: 0;
}

/* Inputs */
.cfca-field input,
.cfca-field select,
.cfca-field textarea,
.cfca-input,
.cfca-select{
  width: 100%;
  min-height: 46px;
  padding: 11px 14px;
  border: 1px solid #cfe2d5;
  border-radius: 14px;
  background: #fff;
  color: #1f2937;
  font-size: .95rem;
  box-sizing: border-box;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.cfca-field input:focus,
.cfca-field select:focus,
.cfca-field textarea:focus,
.cfca-input:focus,
.cfca-select:focus{
  outline: none;
  border-color: var(--cfca-primary-light);
  box-shadow: 0 0 0 4px rgba(76,175,80,.14);
  background: #fff;
}

/* Select + botón + */
.cfca-input-with-action{
  display: grid;
  grid-template-columns: 1fr 44px;
  gap: 8px;
  align-items: stretch;
  margin-bottom: 8px;
}

.cfca-btn-add{
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 14px;
  background: linear-gradient(135deg,var(--cfca-primary) 0%, var(--cfca-primary-light) 100%);
  color: #fff;
  font-size: 1rem;
  font-weight: 900;
  box-shadow: 0 8px 16px rgba(46,125,50,.18);
  transition: transform .18s ease, box-shadow .18s ease;
}

.cfca-btn-add:hover{
  transform: translateY(-1px) scale(1.03);
  box-shadow: 0 10px 18px rgba(46,125,50,.24);
}

/* Bloques internos */
.cfca-field-group h3{
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #d8eadf;
  color: var(--cfca-primary);
  font-size: 1.05rem;
  font-weight: 800;
}

/* Mejor para checkbox */
.cfca-checkbox-field{
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid #dcebe1;
}

/* Responsive */
@media (max-width: 900px){
  .cfca-form-grid,
  .cfca-field-row{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px){
  .cfca-editor{
    margin: 16px auto;
    border-radius: 18px;
  }

  .cfca-editor-header{
    padding: 14px;
  }

  .cfca-btn-primary{
    width: 100%;
  }

  .cfca-editor-tabs{
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    padding: 10px;
    scrollbar-width: thin;
  }

  .cfca-editor-tabs::-webkit-scrollbar{
    height: 6px;
  }

  .cfca-editor-tabs::-webkit-scrollbar-thumb{
    background: #cfe7d6;
    border-radius: 999px;
  }

  .cfca-editor-tab{
    flex: 0 0 auto;
    min-height: 40px;
    padding: 9px 14px;
    font-size: .9rem;
  }

  .cfca-form-panel{
    padding: 12px;
  }

  .tab-content{
    padding: 12px;
    border-radius: 16px;
  }

  .cfca-field,
  .cfca-field-group{
    padding: 12px;
    border-radius: 16px;
  }
}
/* --- END FIX --- */



/* =============================================================
   AJUSTE VISUAL PREMIUM 5.4.6
   ============================================================= */

.cfca-container,
.cfca-public-scope,
[data-cfca-scope="public"] {
    --cfca-premium-green: #234b33;
    --cfca-premium-green-soft: #edf5ef;
    --cfca-premium-border: #d4e5d8;
    --cfca-premium-shadow: 0 12px 32px rgba(35, 75, 51, 0.08);
    --cfca-premium-shadow-hover: 0 16px 36px rgba(35, 75, 51, 0.14);
}

.cfca-view-selector {
    padding: 6px;
    gap: 6px;
    border: 1px solid #dceadf;
    box-shadow: 0 10px 24px rgba(35, 75, 51, 0.08);
}

.cfca-view-btn,
.cfca-view-selector .cfca-btn-secondary {
    min-height: 46px;
    padding: 10px 20px;
    border-radius: 999px;
    font-size: 0.92rem;
    letter-spacing: 0.2px;
}

.cfca-view-btn.active {
    box-shadow: 0 10px 22px rgba(35, 75, 51, 0.25);
}

.cfca-filters {
    padding: 22px 26px;
    border: 1px solid var(--cfca-premium-border);
    box-shadow: var(--cfca-premium-shadow);
    background: linear-gradient(180deg, #ffffff 0%, #fbfdfb 100%);
}

.cfca-filter-group {
    gap: 12px;
    align-items: center;
    margin-bottom: 16px;
}

.cfca-search-wrapper,
.cfca-select,
.cfca-search-input,
.cfca-btn,
.cfca-btn-secondary {
    align-self: center;
}

.cfca-search-input,
.cfca-select {
    min-height: 54px;
    height: 54px;
    padding-top: 10px;
    padding-bottom: 10px;
    border-radius: 18px;
    font-size: 0.96rem;
    line-height: 1.2;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.03);
}

.cfca-search-input {
    padding-left: 50px;
    padding-right: 16px;
}

.cfca-search-icon {
    left: 16px;
    font-size: 1.08rem;
}

.cfca-select {
    padding-left: 16px;
    padding-right: 40px;
    background-position: right 14px center;
    text-align: center;
    text-align-last: center;
}

.cfca-select option {
    text-align: left;
}

.cfca-btn,
.cfca-btn-secondary,
.cfca-filters .cfca-btn,
.cfca-filters .cfca-btn-secondary {
    min-height: 54px;
    padding: 10px 18px;
    border-radius: 18px;
    font-size: 0.96rem;
}

.cfca-checkbox-group,
.cfca-toggle-group,
.cfca-quick-filters,
.cfca-filter-toggles {
    gap: 10px;
    align-items: center;
}

.cfca-table-container {
    border: 1px solid #dfeae2;
    box-shadow: var(--cfca-premium-shadow);
}

.cfca-table thead,
.cfca-table tr:first-child th {
    background: linear-gradient(180deg, #f2f7f3 0%, #e7f0ea 100%) !important;
}

.cfca-table th,
.cfca-table tr:first-child th {
    color: var(--cfca-premium-green) !important;
    background: transparent;
    border-bottom: 1px solid #d6e5da;
    font-weight: 700;
    text-shadow: none;
}

.cfca-table th::after {
    background: rgba(35, 75, 51, 0.14);
}

.cfca-table td {
    padding-top: 14px;
    padding-bottom: 14px;
}

.cfca-table tbody tr:hover {
    box-shadow: 0 6px 18px rgba(35, 75, 51, 0.10);
}

@media (max-width: 768px) {
    .cfca-filters {
        padding: 18px;
    }

    .cfca-filter-group {
        gap: 10px;
    }

    .cfca-search-input,
    .cfca-select,
    .cfca-btn,
    .cfca-btn-secondary {
        min-height: 50px;
        height: 50px;
        border-radius: 16px;
    }

    .cfca-view-btn,
    .cfca-view-selector .cfca-btn-secondary {
        min-height: 42px;
        padding: 9px 16px;
    }
}


/* =============================================================
   CALENDARIO FCA 6.0.0 - OVERRIDES DE CONTRASTE Y COMPACTACIÓN
   ============================================================= */

.cfca-container .cfca-filters {
    padding: 20px;
    border-radius: 22px;
}

.cfca-container .cfca-filter-group {
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 14px;
}

.cfca-container .cfca-search-wrapper {
    min-width: 260px;
}

.cfca-container .cfca-search-input {
    min-height: 54px;
    padding: 11px 16px 11px 44px;
    border-radius: 18px;
    border-width: 1px;
}

.cfca-container .cfca-search-icon {
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.05rem;
    color: #6b7280;
}

.cfca-container .cfca-select,
.cfca-container select.cfca-select {
    min-height: 54px;
    padding: 10px 18px;
    border-radius: 18px;
    border-width: 1px;
    text-align: center;
    text-align-last: center;
    line-height: 1.2;
}

.cfca-container .cfca-btn-primary,
.cfca-container .cfca-btn-secondary {
    min-height: 50px;
    padding: 10px 22px;
    border-radius: 18px;
    line-height: 1.1;
}

.cfca-container .cfca-checkbox-group {
    gap: 12px;
    justify-content: space-between;
    margin-top: 12px;
}

.cfca-container .cfca-checkbox-label {
    padding: 7px 14px;
    border-radius: 16px;
    line-height: 1.2;
}

.cfca-container .cfca-counter {
    margin-top: 0;
    margin-left: auto;
    padding: 10px 18px;
    border-radius: 16px;
    background: #eef7ef;
    color: #1f4d2e;
    border: 1px solid #d8ead9;
    font-weight: 600;
}

.cfca-container .cfca-table th,
.cfca-table th {
    background: linear-gradient(135deg, #f3faf4 0%, #e7f3e8 100%);
    color: #1f4d2e;
    border-bottom: 1px solid #d7e7d8;
    letter-spacing: 0.01em;
}

.cfca-container .cfca-table thead th span,
.cfca-container .cfca-table thead th strong {
    color: inherit;
}

.cfca-container .cfca-table td {
    vertical-align: middle;
}

@media (max-width: 782px) {
    .cfca-container .cfca-filters {
        padding: 16px;
    }

    .cfca-container .cfca-filter-group {
        gap: 8px;
    }

    .cfca-container .cfca-search-wrapper,
    .cfca-container .cfca-select,
    .cfca-container .cfca-btn-primary {
        width: 100%;
        min-width: 100%;
    }

    .cfca-container .cfca-checkbox-group {
        justify-content: flex-start;
    }

    .cfca-container .cfca-counter {
        width: 100%;
        margin-left: 0;
        text-align: center;
    }
}


/* =============================================================
   AJUSTES V6.2.0 PRO
   ============================================================= */
.cfca-container,
.cfca-public-scope,
.cfca-admin-scope,
[data-cfca-scope="public"],
[data-cfca-scope="admin"] {
    --cfca-secondary: #2f6f43;
    --cfca-dark: #173224;
    --cfca-border: #d9e9dc;
}

.cfca-container .cfca-table thead,
.cfca-public-scope .cfca-table thead,
[data-cfca-scope="public"] .cfca-table thead {
    background: linear-gradient(135deg, #edf8ef 0%, #dff0e4 100%) !important;
}

.cfca-container .cfca-table th,
.cfca-public-scope .cfca-table th,
[data-cfca-scope="public"] .cfca-table th {
    color: #14532d !important;
    text-shadow: none !important;
}

.cfca-filters {
    padding: 20px;
}

.cfca-filter-group {
    gap: 10px;
    margin-bottom: 12px;
    align-items: center;
}

.cfca-search-input,
.cfca-select,
.cfca-btn-primary,
.cfca-btn-secondary {
    min-height: 42px;
    padding-top: 10px;
    padding-bottom: 10px;
}

.cfca-view-selector {
    padding: 6px;
    gap: 6px;
}

.cfca-view-btn {
    padding: 10px 18px;
    font-size: 0.92rem;
}


/* =============================================================
   AJUSTES V6.3.0 PRO LIMPIO
   ============================================================= */
.cfca-container .cfca-filters,
.cfca-public-scope .cfca-filters,
[data-cfca-scope="public"] .cfca-filters {
    padding: 16px !important;
    border-radius: 20px !important;
    box-shadow: 0 8px 24px rgba(17, 24, 39, 0.06) !important;
}

.cfca-container .cfca-filter-group,
.cfca-public-scope .cfca-filter-group,
[data-cfca-scope="public"] .cfca-filter-group {
    gap: 8px !important;
    margin-bottom: 10px !important;
}

.cfca-container .cfca-search-input,
.cfca-container .cfca-select,
.cfca-container .cfca-btn-primary,
.cfca-container .cfca-btn-secondary,
.cfca-public-scope .cfca-search-input,
.cfca-public-scope .cfca-select,
.cfca-public-scope .cfca-btn-primary,
.cfca-public-scope .cfca-btn-secondary,
[data-cfca-scope="public"] .cfca-search-input,
[data-cfca-scope="public"] .cfca-select,
[data-cfca-scope="public"] .cfca-btn-primary,
[data-cfca-scope="public"] .cfca-btn-secondary {
    min-height: 40px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
}

.cfca-container .cfca-search-input,
.cfca-public-scope .cfca-search-input,
[data-cfca-scope="public"] .cfca-search-input {
    padding: 9px 14px 9px 40px !important;
}

.cfca-container .cfca-select,
.cfca-public-scope .cfca-select,
[data-cfca-scope="public"] .cfca-select {
    padding: 8px 12px !important;
    color: #14532d !important;
    font-weight: 600 !important;
}

.cfca-container .cfca-btn-primary,
.cfca-public-scope .cfca-btn-primary,
[data-cfca-scope="public"] .cfca-btn-primary {
    box-shadow: 0 6px 16px rgba(22, 101, 52, 0.22) !important;
}

.cfca-container .cfca-btn-secondary,
.cfca-public-scope .cfca-btn-secondary,
[data-cfca-scope="public"] .cfca-btn-secondary {
    background: #fff !important;
}

.cfca-container .cfca-view-selector,
.cfca-public-scope .cfca-view-selector,
[data-cfca-scope="public"] .cfca-view-selector {
    padding: 5px !important;
    gap: 5px !important;
    border: 1px solid #dbe8dd !important;
}

.cfca-container .cfca-view-btn,
.cfca-public-scope .cfca-view-btn,
[data-cfca-scope="public"] .cfca-view-btn {
    padding: 8px 14px !important;
    font-size: 13px !important;
}

.cfca-container .cfca-table th,
.cfca-public-scope .cfca-table th,
[data-cfca-scope="public"] .cfca-table th {
    color: #14532d !important;
    font-weight: 700 !important;
}

.cfca-container .cfca-table td,
.cfca-public-scope .cfca-table td,
[data-cfca-scope="public"] .cfca-table td {
    color: #1f2937;
}

.cfca-container.is-filtering .cfca-table-container,
.cfca-container.is-filtering .cfca-cards-container,
.cfca-container.is-filtering .cfca-agenda-container {
    opacity: .72;
    transition: opacity .18s ease;
}

.cfca-container.is-filtering .cfca-filters::after {
    content: 'Actualizando…';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 8px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #ecfdf3;
    color: #166534;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid #cce7d3;
}

@media (max-width: 782px) {
    .cfca-container .cfca-counter,
    .cfca-public-scope .cfca-counter,
    [data-cfca-scope="public"] .cfca-counter {
        width: 100%;
        margin-left: 0 !important;
        text-align: center !important;
    }

    .cfca-container .cfca-view-btn,
    .cfca-public-scope .cfca-view-btn,
    [data-cfca-scope="public"] .cfca-view-btn {
        flex: 1 1 calc(50% - 6px);
        justify-content: center;
    }
}


/* =========================================================
   AJUSTES V6.3.2 PRO - estados, ayudas e integración calendar
   ========================================================= */
.cfca-badge-hidden{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3;}
.cfca-badge-past{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;}
.cfca-row-status{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px;}
.cfca-status-note{margin:14px 0 6px;padding:12px 14px;border-radius:12px;background:#f8fbf7;border:1px solid #d7ead7;display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap;}
.cfca-status-note-text{color:#45624a;line-height:1.45;flex:1 1 280px;}
.cfca-inline-help{margin-bottom:12px;padding:10px 12px;border-radius:12px;background:#f7fbf7;border:1px solid #dcefdc;color:#49654d;font-size:.94rem;}
.cfca-input-with-action{display:flex;align-items:center;gap:8px;}
.cfca-input-with-action .cfca-input{flex:1 1 auto;}
.cfca-open-url-btn{min-width:42px;padding-inline:10px;}
.cfca-export-help{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f4fbf4;border:1px solid #d8ead8;color:#315537;font-size:.82rem;font-weight:700;}
