/* ═══════════════════════════════════════════════════════════
   Life Peticiones de Oración — Estilos v1.0.0
═══════════════════════════════════════════════════════════ */

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

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

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

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

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

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

.lpo-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;
}
.lpo-btn-submit:hover { background: #219a52; }

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

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

/* ── Botones generales ──────────────────────────────────── */
.lpo-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;
}
.lpo-btn-secondary { background: var(--lpo-azul); color: #fff; }
.lpo-btn-secondary:hover { background: #0f2540; color: #fff; }
.lpo-btn-ghost { background: #e9ecef; color: #444; }
.lpo-btn-ghost:hover { background: #d0d5dc; }
.lpo-btn-excel { background: #1e7e34; color: #fff; }
.lpo-btn-excel:hover { background: #166428; }
.lpo-btn-print { background: #5a6a7a; color: #fff; }
.lpo-btn-print:hover { background: #3d4c5c; }
.lpo-btn-guardar { background: var(--lpo-azul); color: #fff; padding: 10px 24px; font-size: 14px; margin-top: 16px; }
.lpo-btn-guardar:hover { background: #0f2540; }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* ── Header lista + botones anti-Elementor ───────────────── */
.lpo-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;
}
.lpo-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;
}
.lpo-total-badge {
    background: #1a3a5c !important;
    color: #fff !important;
    border-radius: 20px !important;
    padding: 2px 10px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}
.lpo-acciones-derecha {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}
.lpo-panel button.lpo-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;
}
.lpo-panel button.lpo-lista-btn-imprimir:hover { background: #0f2540 !important; }

.lpo-panel button.lpo-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;
}
.lpo-panel button.lpo-lista-btn-copiar:hover {
    background: #1a3a5c !important;
    color: #fff !important;
}

/* ── Botones analítica anti-Elementor ────────────────────── */
.lpo-filtros-con-acciones,
.lpo-filtros.lpo-filtros-con-acciones {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
}
.lpo-analitica-acciones {
    display: flex !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}
.lpo-panel button.lpo-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;
}
.lpo-panel button.lpo-analitica-btn-imprimir:hover { background: #0f2540 !important; }

.lpo-panel button.lpo-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;
}
.lpo-panel button.lpo-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;
}

