/* =================================================================
   ESTILOS PARA EL PORTAL DEL CLIENTE (FRONTEND)
   ================================================================= */

/* Contenedor principal y cabecera del portal */
.lsp-portal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #e0e0e0;
}

.lsp-portal-title {
    font-size: 24px !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}

.lsp-user-menu {
    display: flex;
    align-items: center;
    gap: 10px;
}

.lsp-user-avatar {
    border-radius: 50%;
}

.lsp-logout-link {
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    color: #c00;
    font-weight: bold;
    font-size: 14px;
}

.lsp-logout-link svg {
    width: 16px;
    height: 16px;
}

/* Títulos de sección */
h2.lsp-section-title {
    font-size: 20px !important;
    margin-top: 40px !important;
    margin-bottom: 15px !important;
    padding-bottom: 5px !important;
    border-bottom: 1px solid #eee;
    line-height: 1.3 !important;
}

/* Cuadrícula de KPIs */
.lsp-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
}

.lsp-kpi-card {
    background-color: #fff;
    border-radius: 8px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 15px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.07);
    border: 1px solid #e9ecef;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

.lsp-kpi-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}

.lsp-kpi-icon-wrapper {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.lsp-kpi-icon-wrapper svg {
    width: 24px;
    height: 24px;
}

.lsp-kpi-icon-wrapper.pagadas { background-color: #d4edda; color: #155724; }
.lsp-kpi-icon-wrapper.pendientes { background-color: #fff3cd; color: #856404; }
.lsp-kpi-icon-wrapper.vencidas { background-color: #f8d7da; color: #721c24; }
.lsp-kpi-icon-wrapper.total { background-color: #d1ecf1; color: #0c5460; }
.lsp-kpi-icon-wrapper.total-gestiones { background-color: #cce5ff; color: #004085; }
.lsp-kpi-icon-wrapper.en-proceso { background-color: #e2e3e5; color: #383d41; }
.lsp-kpi-icon-wrapper.finalizadas { background-color: #d4edda; color: #155724; }

.lsp-kpi-text {
    display: flex;
    flex-direction: column;
}

.lsp-kpi-value {
    font-size: 28px;
    font-weight: bold;
    color: #333;
    line-height: 1;
}

.lsp-kpi-label {
    font-size: 14px;
    color: #6c757d;
}

/* Cuadrícula de Gráficos */
.lsp-charts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    margin-bottom: 40px;
}

.lsp-chart-container {
    background: #fff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.07);
    border: 1px solid #e9ecef;
}

/* Tablas de datos */
.lsp-portal-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.07);
}
.lsp-portal-table th, .lsp-portal-table td {
    padding: 12px 15px;
    text-align: left;
    border-bottom: 1px solid #ddd;
}
.lsp-portal-table th {
    background-color: #f8f9fa;
    font-weight: bold;
}
.lsp-portal-table tbody tr:hover {
    background-color: #f1f1f1;
}

/* =================================================================
   ESTILOS PARA LOGIN, RECUPERACIÓN, ETC.
   ================================================================= */

.lsp-login-form-container { max-width: 400px; margin: 40px auto; padding: 30px; border: 1px solid #e0e0e0; border-radius: 8px; background-color: #f9f9f9; box-shadow: 0 4px 10px rgba(0,0,0,0.05); }
.lsp-login-form-container form { display: flex; flex-direction: column; }
.lsp-login-form-container label { font-weight: bold; margin-top: 15px; margin-bottom: 5px; }
.lsp-login-form-container input[type="text"],
.lsp-login-form-container input[type="password"] { padding: 10px; border: 1px solid #ddd; border-radius: 5px; font-size: 16px; width: 100%; box-sizing: border-box; }
.lsp-login-form-container .login-remember { margin-top: 15px; display: flex; align-items: center; }
.lsp-login-form-container .login-remember label { margin: 0 0 0 5px; font-weight: normal; }
.lsp-login-form-container .login-submit input, .lsp-login-form-container .submit input { width: 100%; padding: 12px; margin-top: 20px; border: none; border-radius: 5px; background-color: #0073aa; color: white; font-size: 16px; font-weight: bold; cursor: pointer; transition: background-color 0.2s; }
.lsp-login-form-container .login-submit input:hover, .lsp-login-form-container .submit input:hover { background-color: #005f8a; }
.lsp-login-error, .lsp-login-success { border-radius: 5px; padding: 15px; margin-bottom: 20px; border: 1px solid transparent; }
.lsp-login-error { background-color: #ffebe8; border-color: #c00; color: #c00; }
.lsp-login-success { background-color: #e8f5e9; border-color: #4caf50; color: #2e7d32; }
.lsp-login-prompt { text-align: center; padding: 40px 20px; }
.lsp-lost-password-link { text-align: center; margin-top: 20px; display: block; }
