/* ═══════════════════════════════════════════════════════════
   Life Equipos Ministeriales — Estilos v1.0.0
═══════════════════════════════════════════════════════════ */

/* ── Variables ──────────────────────────────────────────── */
:root {
    --ltm-azul:    #1a3a5c;
    --ltm-verde:   #2e7d32;
    --ltm-gris:    #f4f6f9;
    --ltm-borde:   #dde3ea;
    --ltm-texto:   #2d3748;
    --ltm-radio:   8px;
}

/* ── Panel contenedor ───────────────────────────────────── */
.ltm-panel {
    background: #fff;
    border-radius: var(--ltm-radio);
    border: 1px solid var(--ltm-borde);
    padding: 20px;
    margin: 0 0 20px;
    box-sizing: border-box;
}

/* ── Formulario ─────────────────────────────────────────── */
.ltm-form-wrap { max-width: 560px; margin: 0 auto; }

.ltm-form { display: flex; flex-direction: column; gap: 10px; }

.ltm-input {
    width: 100%;
    padding: 12px 14px;
    border: 1.5px solid var(--ltm-borde);
    border-radius: 6px;
    font-size: 14px;
    color: var(--ltm-texto);
    background: #fff;
    box-sizing: border-box;
    transition: border-color .2s;
}
.ltm-input:focus { outline: none; border-color: var(--ltm-azul); }
.ltm-textarea { resize: vertical; min-height: 80px; }

.ltm-fieldset {
    border: 1.5px solid var(--ltm-borde);
    border-radius: 6px;
    padding: 12px 14px;
    margin: 0;
}
.ltm-legend {
    font-size: 13px;
    font-weight: 600;
    color: var(--ltm-azul);
    padding: 0 6px;
}
.ltm-checks {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 6px;
    margin-top: 8px;
}
.ltm-check-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    cursor: pointer;
}
.ltm-check-label input[type="checkbox"] { margin: 0; }

.ltm-btn-submit {
    width: 100%;
    padding: 14px;
    background: #27ae60;
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: .5px;
    cursor: pointer;
    transition: background .2s;
}
.ltm-btn-submit:hover { background: #219a52; }

.ltm-errores {
    background: #fff5f5;
    border: 1px solid #feb2b2;
    border-radius: 6px;
    padding: 12px 16px;
    margin-bottom: 12px;
    font-size: 13px;
    color: #c53030;
}
.ltm-errores p { margin: 0 0 4px; }

.ltm-exito {
    text-align: center;
    padding: 30px 20px;
    background: #f0faf4;
    border: 1px solid #9ae6b4;
    border-radius: var(--ltm-radio);
}
.ltm-exito-icono { font-size: 40px; margin-bottom: 10px; }
.ltm-exito strong { font-size: 18px; color: var(--ltm-verde); display: block; margin-bottom: 8px; }
.ltm-exito p { color: #555; font-size: 14px; margin: 0; }

/* ── Botones generales ──────────────────────────────────── */
.ltm-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 6px;
    border: none;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
    text-decoration: none;
}
.ltm-btn-secondary { background: var(--ltm-azul); color: #fff; }
.ltm-btn-secondary:hover { background: #0f2540; color: #fff; }
.ltm-btn-ghost { background: #e9ecef; color: #444; }
.ltm-btn-ghost:hover { background: #d0d5dc; }
.ltm-btn-excel { background: #1e7e34; color: #fff; }
.ltm-btn-excel:hover { background: #166428; }
.ltm-btn-print { background: #5a6a7a; color: #fff; }
.ltm-btn-print:hover { background: #3d4c5c; }
.ltm-btn-guardar { background: var(--ltm-azul); color: #fff; padding: 10px 24px; font-size: 14px; margin-top: 16px; }
.ltm-btn-guardar:hover { background: #0f2540; }

/* ── Barra de filtros + acciones ────────────────────────── */
.ltm-filtros-barra {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--ltm-borde);
}
.ltm-filtros-con-acciones {
    justify-content: space-between;
    align-items: center;
}
.ltm-filtros-form {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    flex: 1;
    align-items: center;
}
.ltm-input-filtro {
    padding: 7px 10px;
    border: 1.5px solid var(--ltm-borde);
    border-radius: 6px;
    font-size: 13px;
    background: #fff;
}
.ltm-input-filtro:focus { outline: none; border-color: var(--ltm-azul); }
.ltm-select { min-width: 160px; }
.ltm-acciones { display: flex; gap: 8px; flex-shrink: 0; }

.ltm-rango-wrap { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; }
.ltm-campo-fecha { display: flex; flex-direction: column; gap: 3px; }
.ltm-campo-fecha label { font-size: 11px; font-weight: 600; color: #666; text-transform: uppercase; }
.ltm-campo-fecha input { padding: 7px 10px; border: 1.5px solid var(--ltm-borde); border-radius: 6px; font-size: 13px; }

.ltm-periodo-label { font-size: 12px; color: #666; margin: 6px 0 0; width: 100%; }
.ltm-total-label { font-size: 13px; color: #555; margin: 0 0 12px; }

/* ── Tabla ──────────────────────────────────────────────── */
.ltm-table-wrap { overflow-x: auto; }
.ltm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.ltm-table th {
    background: var(--ltm-azul);
    color: #fff;
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    white-space: nowrap;
}
.ltm-table td {
    padding: 9px 12px;
    border-bottom: 1px solid #eef0f3;
    color: var(--ltm-texto);
    vertical-align: middle;
}
.ltm-table tbody tr:nth-child(even) td { background: #f9fafb; }
.ltm-table tbody tr:hover td { background: #eef4ff; }
.ltm-table-small td, .ltm-table-small th { padding: 7px 10px; font-size: 12px; }
.ltm-td-center { text-align: center !important; }

/* ── Badges categoría ───────────────────────────────────── */
.ltm-badge-equipo {
    display: inline-block;
    background: #e8f0fe;
    color: var(--ltm-azul);
    border-radius: 20px;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    margin: 2px 2px 2px 0;
}

/* ── Detalle celda ──────────────────────────────────────── */
.ltm-detalle-cel { max-width: 200px; }
.ltm-detalle-corto { color: #555; font-size: 12px; }
.ltm-btn-ver-detalle {
    background: none;
    border: none;
    color: var(--ltm-azul);
    font-size: 11px;
    cursor: pointer;
    padding: 0 4px;
    text-decoration: underline;
}

/* ── Box total analítica ────────────────────────────────── */
.ltm-box-total {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--ltm-azul);
    color: #fff;
    border-radius: var(--ltm-radio);
    padding: 18px 24px;
    margin-bottom: 20px;
}
.ltm-box-icono { font-size: 32px; }
.ltm-box-numero { font-size: 36px; font-weight: 800; line-height: 1; }
.ltm-box-label { font-size: 14px; opacity: .85; }

/* ── Layout 2 columnas analítica ────────────────────────── */
.ltm-analitica-cols {
    display: grid;
    grid-template-columns: 60% 40%;
    gap: 20px;
    align-items: start;
}
.ltm-section-titulo {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--ltm-azul);
    margin-bottom: 14px;
}

/* ── Barras categorías ──────────────────────────────────── */
.ltm-cats-lista { display: flex; flex-direction: column; gap: 8px; }
.ltm-cat-row {
    display: grid;
    grid-template-columns: 110px 1fr 36px;
    align-items: center;
    gap: 8px;
}
.ltm-cat-label { font-size: 13px; font-weight: 600; color: var(--ltm-texto); }
.ltm-cat-bar-wrap { background: #e9ecef; border-radius: 20px; height: 10px; overflow: hidden; }
.ltm-cat-bar { height: 100%; background: var(--ltm-azul); border-radius: 20px; transition: width .5s; }
.ltm-cat-count { font-size: 13px; font-weight: 700; color: var(--ltm-azul); text-align: right; }

/* ── Config page ────────────────────────────────────────── */
.ltm-config-card {
    background: #fff;
    border: 1px solid var(--ltm-borde);
    border-radius: var(--ltm-radio);
    overflow: hidden;
}
.ltm-config-seccion {
    padding: 20px 24px;
    border-bottom: 1px solid var(--ltm-borde);
}
.ltm-config-seccion:last-child { border-bottom: none; }
.ltm-config-label { font-size: 14px; font-weight: 700; color: var(--ltm-azul); display: block; margin-bottom: 4px; }
.ltm-config-desc { font-size: 12px; color: #777; margin: 0 0 10px; }
.ltm-config-input {
    width: 100%;
    max-width: 500px;
    padding: 9px 12px;
    border: 1.5px solid var(--ltm-borde);
    border-radius: 6px;
    font-size: 13px;
    box-sizing: border-box;
}
.ltm-sc-grid { display: flex; flex-direction: column; gap: 8px; }
.ltm-sc-item { display: flex; align-items: center; gap: 12px; }
.ltm-sc-item code {
    background: #f1f3f5;
    border: 1px solid #dde;
    border-radius: 4px;
    padding: 3px 8px;
    font-size: 13px;
    white-space: nowrap;
}
.ltm-sc-item span { font-size: 13px; color: #555; }

/* ── Modal ──────────────────────────────────────────────── */
.ltm-modal {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ltm-modal-box {
    background: #fff;
    border-radius: var(--ltm-radio);
    padding: 24px;
    max-width: 480px;
    width: 90%;
    position: relative;
    box-shadow: 0 8px 32px rgba(0,0,0,.15);
}
.ltm-modal-cerrar {
    position: absolute;
    top: 12px; right: 14px;
    background: none; border: none;
    font-size: 18px; cursor: pointer; color: #888;
}
.ltm-modal-titulo { font-weight: 700; color: var(--ltm-azul); font-size: 15px; margin: 0 0 12px; }

/* ── Acceso denegado / vacío ────────────────────────────── */
.ltm-acceso-denegado { color: #e53e3e; font-size: 14px; }
.ltm-vacio { color: #888; font-style: italic; font-size: 13px; padding: 20px 0; text-align: center; }

/* ── Print ──────────────────────────────────────────────── */
@media print {
    .ltm-filtros-barra, .ltm-acciones, .ltm-btn,
    .ltm-btn-ver-detalle, .ltm-modal, #wpadminbar,
    header, footer, nav { display: none !important; }
    .ltm-panel { border: none; padding: 0; }
    .ltm-table th { background: #1a3a5c !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
    .ltm-badge-equipo { background: #ddd !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 700px) {
    .ltm-analitica-cols { grid-template-columns: 1fr; }
    .ltm-cat-row { grid-template-columns: 90px 1fr 30px; }
    .ltm-filtros-con-acciones { flex-direction: column; align-items: flex-start; }
}

/* ── Badges equipo (colores por ministerio) ─────────────── */
.ltm-badge-equipo {
    display: inline-block;
    background: #e8f0fe;
    color: #1a3a5c;
    border-radius: 20px;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    margin: 2px 2px 2px 0;
}

/* Barras equipos */
.ltm-equipos-lista { display: flex; flex-direction: column; gap: 8px; }
.ltm-eq-row {
    display: grid;
    grid-template-columns: 130px 1fr 36px;
    align-items: center;
    gap: 8px;
}
.ltm-eq-label  { font-size: 13px; font-weight: 600; color: #2d3748; }
.ltm-eq-bar-wrap { background: #e9ecef; border-radius: 20px; height: 10px; overflow: hidden; }
.ltm-eq-bar    { height: 100%; background: #1a3a5c; border-radius: 20px; transition: width .5s; }
.ltm-eq-count  { font-size: 13px; font-weight: 700; color: #1a3a5c; text-align: right; }

/* ── Header lista + botones anti-Elementor ───────────────── */
.ltm-lista-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
}
.ltm-total-label {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #1a3a5c !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}
.ltm-total-badge {
    background: #1a3a5c !important;
    color: #fff !important;
    border-radius: 20px !important;
    padding: 2px 10px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}
.ltm-acciones-derecha {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}
.ltm-panel button.ltm-lista-btn-imprimir {
    all: unset !important;
    box-sizing: border-box !important;
    background: #1a3a5c !important;
    color: #fff !important;
    border-radius: 6px !important;
    padding: 9px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.ltm-panel button.ltm-lista-btn-imprimir:hover { background: #0f2540 !important; }

.ltm-panel button.ltm-lista-btn-copiar {
    all: unset !important;
    box-sizing: border-box !important;
    background: #fff !important;
    color: #1a3a5c !important;
    border: 2px solid #1a3a5c !important;
    border-radius: 6px !important;
    padding: 7px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.ltm-panel button.ltm-lista-btn-copiar:hover {
    background: #1a3a5c !important;
    color: #fff !important;
}

/* ── Botones analítica anti-Elementor ────────────────────── */
.ltm-filtros-con-acciones,
.ltm-filtros.ltm-filtros-con-acciones {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
}
.ltm-analitica-acciones {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}
.ltm-panel button.ltm-analitica-btn-imprimir {
    all: unset !important;
    box-sizing: border-box !important;
    background: #1a3a5c !important;
    color: #fff !important;
    border-radius: 6px !important;
    padding: 9px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.ltm-panel button.ltm-analitica-btn-imprimir:hover { background: #0f2540 !important; }

.ltm-panel button.ltm-analitica-btn-copiar {
    all: unset !important;
    box-sizing: border-box !important;
    background: #fff !important;
    color: #1a3a5c !important;
    border: 2px solid #1a3a5c !important;
    border-radius: 6px !important;
    padding: 7px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.ltm-panel button.ltm-analitica-btn-copiar:hover {
    background: #1a3a5c !important;
    color: #fff !important;
}

/* == Filtros grid 2 columnas == */
.lpo-filtros-grid2,.ltm-filtros-grid2 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px 16px !important;
    width: 100% !important;
}
.lpo-filtro-campo,.ltm-filtro-campo {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}
.lpo-filtro-label,.ltm-filtro-label {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #666 !important;
    text-transform: uppercase !important;
    letter-spacing: .4px !important;
}
.lpo-filtro-botones,.ltm-filtro-botones {
    grid-column: 1 / -1 !important;
    display: flex !important;
    gap: 8px !important;
    padding-top: 4px !important;
}
.lpo-input-filtro,.ltm-input-filtro {
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 8px 10px !important;
    border: 1.5px solid #dde3ea !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    background: #fff !important;
}
.lpo-input-filtro:focus,.ltm-input-filtro:focus { outline: none !important; border-color: #1a3a5c !important; }
@media(max-width:600px){
    .lpo-filtros-grid2,.ltm-filtros-grid2 { grid-template-columns: 1fr !important; }
}
/* == Badge nuevos registros == */
.life-badge-nuevo {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #e53e3e !important;
    color: #fff !important;
    border-radius: 50px !important;
    min-width: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 0 6px !important;
    line-height: 1 !important;
    vertical-align: middle !important;
    margin-left: 4px !important;
}

