/* ================================================================
   SHARED COMPONENT STYLES
   File    : CssStyles/CssComponents.css
   Covers  : Cards, tables, badges, buttons, forms,
             pagination, app footer. Used on ALL pages.
   ================================================================ */


/* ----------------------------------------------------------------
   CARDS
   ---------------------------------------------------------------- */
.card         { background: var(--color-white); border-radius: var(--radius); box-shadow: var(--shadow-sm); border: 1px solid var(--color-border); margin-bottom: 20px; overflow: hidden; }
.card-header  { padding: 14px 20px; border-bottom: 1px solid var(--color-border); background-color: #F8F9FC; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.card-title   { font-size: 14.5px; font-weight: 700; color: var(--color-text); }
.card-body    { padding: 20px; }


/* ----------------------------------------------------------------
   DATA TABLES
   ---------------------------------------------------------------- */
.data-table-wrapper { overflow-x: auto; width: 100%; }
.data-table         { width: 100%; border-collapse: collapse; font-size: 13.5px; min-width: 600px; }
.data-table thead   { background-color: #EAECF4; position: sticky; top: 0; z-index: 2; }
.data-table th      { padding: 10px 12px; text-align: left; font-weight: 700; color: var(--color-text); font-size: 12.5px; white-space: nowrap; border-bottom: 2px solid var(--color-border); }
.data-table td      { padding: 9px 12px; border-bottom: 1px solid var(--color-border); color: var(--color-text); vertical-align: middle; }
.data-table tbody tr:hover      { background-color: #F0F2FB; }
.data-table tbody tr:last-child td { border-bottom: none; }
.table-summary { background-color: #EAECF4; font-weight: 700; }


/* ----------------------------------------------------------------
   BADGES
   ---------------------------------------------------------------- */
.badge          { display: inline-block; padding: 3px 9px; border-radius: 20px; font-size: 11.5px; font-weight: 700; white-space: nowrap; }
.badge-active   { background-color: var(--color-success-bg); color: var(--color-success); }
.badge-cancelled{ background-color: var(--color-error-bg);   color: var(--color-error); }
.badge-inactive { background-color: #ECEFF1; color: #333333; }


/* ----------------------------------------------------------------
   BUTTONS
   ---------------------------------------------------------------- */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 16px; border-radius: var(--radius-sm); border: none;
    cursor: pointer; font-size: 12.5px; font-weight: 700;
    text-decoration: none; transition: var(--transition);
    white-space: nowrap; line-height: 1.3; font-family: inherit;
}
.btn:disabled { opacity: .6; cursor: not-allowed; }

.btn-primary   { background-color: var(--color-btn-primary); color: var(--color-white); }
.btn-primary:hover  { filter: brightness(.88); transform: translateY(-1px); text-decoration: none; color: var(--color-white); }

.btn-secondary { background-color: #455A64; color: var(--color-white); }
.btn-secondary:hover { background-color: #37474F; text-decoration: none; color: var(--color-white); }

.btn-danger    { background-color: var(--color-error); color: var(--color-white); }
.btn-danger:hover { background-color: #8B1515; text-decoration: none; color: var(--color-white); }

.btn-neutral   { background-color: #ECEFF1; color: var(--color-text); border: 1px solid var(--color-border); }
.btn-neutral:hover { background-color: #CFD8DC; text-decoration: none; }

.btn-sm    { padding: 4px 10px; font-size: 11.5px; }
.btn-lg    { padding: 10px 22px; font-size: 14.5px; }
.btn-group { display: flex; gap: 8px; flex-wrap: wrap; }


/* ----------------------------------------------------------------
   FORMS
   ---------------------------------------------------------------- */
.form-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group.full-width { grid-column: 1 / -1; }
.form-label  { font-size: 12.5px; font-weight: 700; color: var(--color-text); }
.required-mark { color: var(--color-error); margin-left: 2px; }

.form-control {
    padding: 7px 10px; border: 1px solid var(--color-border);
    border-radius: var(--radius-sm); font-size: 13.5px;
    color: var(--color-text); background: var(--color-white);
    width: 100%; transition: border-color .2s; font-family: inherit;
}
.form-control:focus    { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(21,101,192,.12); }
.form-control[readonly]{ background-color: #F0F2FB; }
.form-control[disabled]{ background-color: #ECEFF1; cursor: not-allowed; opacity: .75; }

.amounts-section { background: #F8F9FC; border: 1px solid var(--color-border); border-radius: var(--radius); padding: 16px; margin-top: 12px; }
.amounts-title   { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 12px; }
.total-field .form-control { font-size: 15.5px; font-weight: 700; color: var(--color-primary); border-color: var(--color-primary); }


/* ----------------------------------------------------------------
   PAGINATION
   ---------------------------------------------------------------- */
.pagination { display: flex; align-items: center; gap: 4px; margin-top: 16px; flex-wrap: wrap; }
.page-btn   { padding: 5px 10px; border: 1px solid var(--color-border); border-radius: var(--radius-sm); background: var(--color-white); color: var(--color-text); cursor: pointer; font-size: 12.5px; font-weight: 600; transition: var(--transition); text-decoration: none; min-width: 34px; text-align: center; font-family: inherit; }
.page-btn:hover,
.page-btn.active { background-color: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); text-decoration: none; }


/* ----------------------------------------------------------------
   APP FOOTER
   ---------------------------------------------------------------- */
.app-footer { text-align: center; padding: 14px; background-color: var(--color-white); border-top: 1px solid var(--color-border); font-size: 11.5px; }


/* ----------------------------------------------------------------
   RESPONSIVE ADDITIONS — Tables, Filters, Forms
   Ajustes para mobile sin modificar logica de procesos.
   ---------------------------------------------------------------- */

/* Tablas: scroll horizontal garantizado en cualquier contenedor */
.data-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;  /* Scroll suave en iOS */
    width: 100%;
}

/* Tablas de Income/Expense tienen 13-14 columnas: min-width mayor */
.data-table { min-width: 700px; }

/* Botones de accion en tabla: siempre en linea, nunca se parten */
.data-table td .btn { white-space: nowrap; }
.data-table .text-nowrap { white-space: nowrap; }

/* Card que contiene tabla: permite overflow para el scroll */
@media (max-width: 768px) {
    .card { overflow: visible; }

    /* Filtros de busqueda: de 5 columnas fijas a responsive */
    /* Aplica a los grids inline de los paneles de filtros */
    [style*="grid-template-columns:repeat(5, 1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Filtros de Clients/Vendors: auto-fit ya es responsive, solo ajuste de minimo */
    [style*="minmax(200px, 1fr)"] {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Seccion de montos en formularios */
    .amounts-section .form-grid {
        grid-template-columns: 1fr 1fr !important;
    }

    /* Botones de accion en tabla: apilados en pantallas pequenas */
    .data-table .text-center.text-nowrap {
        white-space: nowrap;
    }
}

@media (max-width: 480px) {
    /* Filtros: una sola columna en mobile pequeno */
    [style*="grid-template-columns:repeat(5, 1fr)"] {
        grid-template-columns: 1fr !important;
    }
    [style*="minmax(200px, 1fr)"] {
        grid-template-columns: 1fr !important;
    }

    /* Montos: columna unica */
    .amounts-section .form-grid {
        grid-template-columns: 1fr !important;
    }

    /* Card header: titulo y boton apilados */
    .card-header { flex-direction: column; align-items: flex-start; }

    /* Action bar: boton y contador apilados */
    .d-flex.justify-between.align-center { flex-direction: column; align-items: flex-start; }

    /* Paginacion envuelve */
    .pagination { flex-wrap: wrap; }

    /* btn-group envuelve sin desbordarse */
    .btn-group { flex-wrap: wrap; }
}

/* Reports: preview con scroll completo */
.report-preview,
.report-container,
#reportPreview,
#previewContainer {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    max-width: 100%;
}

@media (max-width: 768px) {
    /* Formularios de 2 columnas en read-only (Edit pages) colapsan a 1 */
    .form-grid { grid-template-columns: 1fr !important; }

    /* Overrides para grids inline en las paginas de formularios */
    [style*="grid-column:1/-1"] { grid-column: 1 / -1 !important; }
}


/* ============================================================
   SYSTEM CONFIRMATION MODAL (#sysModal)
   Reemplaza confirm() nativo. Definido en FreFooter.php.
   Se muestra solo cuando tiene la clase "active".
   ============================================================ */

/* Overlay: oculto por defecto, visible solo con clase .active */
.modal-overlay {
    display:         none;               /* Oculto por defecto */
    position:        fixed;
    inset:           0;
    background:      rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(3px);
    align-items:     center;
    justify-content: center;
    z-index:         9999;
    animation:       modal-fade-in 0.18s ease;
}

/* Mostrar solo cuando tiene clase .active */
.modal-overlay.active {
    display: flex;
}

@keyframes modal-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Caja central del modal */
.modal-card {
    background:    #ffffff;
    border-radius: 16px;
    box-shadow:    0 20px 60px rgba(15, 23, 42, 0.22),
                   0 4px  16px rgba(15, 23, 42, 0.10);
    padding:       36px 40px 32px;
    max-width:     420px;
    width:         calc(100% - 40px);
    text-align:    center;
    border-top:    5px solid #CBD5E1;
    animation:     modal-slide-up 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes modal-slide-up {
    from { transform: translateY(24px) scale(0.96); opacity: 0; }
    to   { transform: translateY(0)    scale(1);    opacity: 1; }
}

/* Header: icono + titulo */
.modal-header {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            10px;
    margin-bottom:  14px;
}

/* Icono */
.modal-icon {
    font-size:   2rem;
    line-height: 1;
}
.modal-icon-warning { color: #D97706; }
.modal-icon-danger  { color: #E53E3E; }
.modal-icon-info    { color: #3182CE; }
.modal-icon-success { color: #38A169; }

/* Titulo */
.modal-title {
    font-size:   1.1rem;
    font-weight: 700;
    color:       #1E293B;
}

/* Cuerpo: mensaje */
.modal-body {
    font-size:     0.92rem;
    color:         #475569;
    margin-bottom: 24px;
    white-space:   pre-line;
}

/* Footer: botones */
.modal-footer {
    display:         flex;
    justify-content: center;
    gap:             12px;
}
